



### Instruction Sets Guide

Rev. 21.0

DOC9474-2LA

## Instruction Sets Guide

**Second Edition** 

## by Marilyn Hammond

Prime Computer, Inc. Prime Park Natick, Massachusetts 01760 The information in this document is subject to change without notice and should not be construed as a commitment by Prime Computer, Inc. Prime Computer, Inc., assumes no responsibility for any errors that may appear in this document.

The software described in this document is furnished under a license and may be used or copied only in accordance with the terms of such license.

Copyright © 1987 by Prime Computer, Inc. All rights reserved.

PRIME and PRIMOS are registered trademarks of Prime Computer, Inc. DISCOVER, INFO/BASIC, INFORM, MIDAS, MIDASPLUS, PERFORM, Prime INFORMATION, PRIME/SNA, PRIMELINK, PRIMENET, PRIMEWAY, PRIMIX, PRISAM, PST 100, PT25, PT45, PT65, PT200, PW153, PW200, PW250, RINGNET, SIMPLE, 50 Series, 400, 750, 850, 2250, 2350, 2450, 2550, 2650, 2655, 2755, 6350, 9650, 9655, 9750, 9755, 9950, 9955, and 9955II are trademarks of Prime Computer, Inc.

#### PRINTING HISTORY

First Edition (DOC9474-1LA) January 1985 Update 1 (UPD9474-11A) October 1985 Update 2 (UPD9474-12A) February 1986 Update 3 (UPD9474-13A) April 1986 Second Edition (DOC9474-2LA) August 1987

CREDITS

Editorial: Thelma Henner Project Support: The CPU Group Illustration: Mingling Chang Document Preparation: Kathy Normington Production: Judy Gordon

#### HOW TO ORDER TECHNICAL DOCUMENTS

To order copies of documents, or to obtain a catalog and price list:

#### United States Customers

#### International

Call Prime Telemarketing, toll free, at 1-800-343-2533, Monday through Friday, 8:30 a.m. to 5:00 p.m. (EST). Contact your local Prime subsidiary or distributor.

#### CUSTOMER SUPPORT

Prime provides the following toll-free numbers for customers in the United States needing service:

| 1-800-322-2838 | (within Massachusetts) | ) 1-800-541-8888 | (within Alaska) |
|----------------|------------------------|------------------|-----------------|
| 1-800-343-2320 | (within other states)  | 1-800-651-1313   | (within Hawaii) |

For other locations, contact your Prime representative.

#### SURVEYS AND CORRESPONDENCE

Please comment on this manual using the Reader Response Form provided in the back of this book. Address any additional comments on this or other Prime documents to:

Technical Publications Department Prime Computer, Inc. 500 Old Connecticut Path Framingham, MA 01701

## Contents

|   | ABOUT THIS BOOK                                          | vii                 |
|---|----------------------------------------------------------|---------------------|
| 1 | INTRODUCTION                                             |                     |
|   | Addressing Modes<br>Summary of Datatypes and Applicable  | 1–1                 |
|   | Instructions                                             | 1-5                 |
| 2 | S, R, AND V MODE                                         |                     |
|   | Introduction<br>Instructions                             | 2-1<br>2-7          |
| 3 | I MODE                                                   |                     |
|   | Introduction<br>Instructions                             | 3–1<br>3–7          |
|   | APPENDICES                                               |                     |
| А | Condition Code Information                               | A-1                 |
| В | Addressing Information                                   | B-1                 |
|   | Addressing Modes and Formats<br>Address Traps<br>Summary | B-1<br>B-18<br>B-22 |
| С | Instruction Summary Charts                               | C-1                 |
| D | Hardware Considerations in Performance                   | D-1                 |
|   | Instruction Weights<br>Extensions to Instruction Weights | D-2<br>D-7          |
| Ε | Archived Instructions                                    | E-1                 |
| F | 2455 Instruction Sets                                    | F-1                 |

~

1

## About This Book

Prime's 50 Series <sup>™</sup> family is a sophisticated group of totally compatible supermini computers. Its members are the Prime:

| 6350™              | 9955 II TM | 9955 <sup>™</sup> | 9950 <sup>™</sup> |
|--------------------|------------|-------------------|-------------------|
| 9755 <sup>tm</sup> | 9750 ™     | 9655 <sup>™</sup> | 9650 ™            |
| 2755 <sup>tm</sup> | 2655 TM    | 2550 TM           | <b>2450 ™</b>     |
| 2350 <sup>rm</sup> | 2250 TM    | 850 TM            | 750 TM            |
| 650 <sup>tm</sup>  | 550-II ™   | 550 TM            | 500 TM            |
| 450™               | I450 ™     | <b>4</b> 00 ™     | 350 TM            |
| 250-II™            | 250 TM     | 150 TM            |                   |

The earlier processors are the 2250, 850, 750, 650, 550-II, 550, 500, 450/, I450, 400, 350, 250-II, 250, and 150.

The 50 Series systems embody an advanced 32-bit architecture that grants the user the ability to perform complex tasks efficiently and quickly. This document describes the 50 Series addressing modes and their instructions from a functional point of view.

#### NOTES TO THE READER

Several groups of people will find this document useful: engineers, programmers, designers, and technicians. To read this book, you should have a basic understanding of computers, but not necessarily of Prime computers. Prime stresses a high degree of compatibility across its product line; therefore, you can apply much of the information contained in this book to other Prime machines, as well as to the 50 Series machines.

#### ORGANIZATION OF THIS GUIDE

This guide describes the instructions for S, R, V, and I addressing modes. Each of these modes is introduced in Chapter 1. This chapter also presents the 50 Series datatypes and their applicable instructions. Chapters 2 and 3 contain detailed information about each instruction -- name, format, mnemonic, and required operands -- and a complete description of each of the instruction's actions.

Chapters 1 through 3 may be summarized as follows:

- Chapter 1 contains brief descriptions of S, R, V, and I addressing modes as well as a summary of datatypes with applicable instructions.
- Chapter 2 is a dictionary of instructions executable in S, R, and V modes.
- Chapter 3 is a dictionary of instructions executable in I mode.

Appendix A discusses the condition codes and their interpretation.

Appendix B presents tables of addressing information.

Appendix C contains summary charts of the instructions.

Appendix D discusses hardware considerations in performance and provides tables of relative instruction weights.

Appendix E has those instructions that have been archived.

Appendix F discusses the instructions sets in relation to the 2455.

#### PRIME DOCUMENTATION CONVENTIONS

1

The following conventions are used in command formats, statement formats, and in examples throughout this document. Examples illustrate the uses of these commands and statements in typical applications.

| Convention      | Explanation                                                                                                                                    | Example             |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| UPPERCASE       | In command formats, words<br>in uppercase indicate the<br>names of commands, options,<br>statements, and keywords.<br>Enter them in uppercase. | CRL                 |
| lowercase       | In command formats, words<br>in lowercase indicate vari-<br>ables for which you must<br>substitute a suitable value.                           | LDA address         |
| Brackets<br>[]  | Brackets enclose an optional item.                                                                                                             | [ DISPLACEMENT\16 ] |
| Apostrophe<br>, | An apostrophe preceding a number indicates that the number is in octal.                                                                        | '200                |

## **1** Introduction

This chapter briefly describes the S, R, V, and I addressing modes as well as introducing their data representations. Each datatype operation is listed with its S, R, V, and I mode instructions.

#### ADDRESSING MODES

The 50 Series processors support four addressing modes, each of which forms addresses differently. Depending on the program and personal preference, one or two of these modes may be more useful than another. The three most important modes are:

- V, or virtual
- I, or general register
- R, or relative

The fourth mode -- S, or sectored, mode -- is supported for historical reasons.

#### V Mode

V mode performs short and long operations and has a wide variety of registers to use. A short (16-bit) instruction in this mode can reference the first 256 locations of both the stack and link, as well as the 224 locations on either side of the current location in the procedure segment. A long (32-bit) V mode instruction can directly reference all locations in four segments. Indirect addressing can reference all locations in up to 4096 128-Kbyte segments.

#### I Mode

When referencing memory, I mode is similar to 32-bit V mode. The difference is that I mode short operations reference 8 32-bit general purpose registers for use as index registers, accumulators, counters, or the like. I mode long operations have the same referencing power as V mode long operations. They can also use immediate forms and five additional index registers. (This makes a total of 7 index registers that I mode long operations can use.) The index registers are specified by the source register field. General register 0, however, cannot be used for indexing.

General register relative (GRR) is an addressing capability added to 32I mode that speeds up big array accesses and often gives the effect of using general registers as base registers. (This is sometimes called IX mode.) The offset is formed in GRR by adding the displacement to bits 17 to 32 of the source register field. GRR is used by the I mode instructions AIP and LIP. (GRR is not available for the earlier processors listed in "About This Book".)

The C language pointer is used by the I mode instructions ACP, OCP, DCP, ICP, LOC, SOC, and TCNP. The format of this pointer is the same as the indirect pointer, except that bit 4 is redefined as the B (byte) bit. When this bit contains 0, it indicates that bits 1 to 8 (the left byte) of an address contain the character to be used; when this bit contains 1, bits 9 to 16 (the right byte) of an address contain the character. A null pointer is represented by a 0 in bits 4 through 32. (The C language pointer and its instructions are not available for the earlier processors listed in "About This Book".)

Normal effective address formation uses either a base register, indirect pointer (IP) or a general register (for GRR addressing) as the source of the ring field, B bit, and segment number. The C language pointer is well defined for the IP and GRR form. When the base register is the source of the B bit, software depends on finding it reset to zero, pointing to the leftmost byte. While it is possible to set the E bit in a base register using 48-bit IPs to specify 32-bit addresses, this practice is not now done. Future implementations of V and I modes will force bit 4 to zero during effective address formation when the source of the segment is a base register; otherwise it will copy bit 4.

#### R Mode

A <u>sector</u> is a block of 512 (1000 octal) contiguous memory locations. Sector 0 starts on location 0 and ends on location '777; Sector 1 begins on location '1000 and ends on location '1777; and so on.

An R mode instruction can reference any location in Sector 0, as well as a group of locations relative to the current value of the program counter. When the sector bit (S) in an R mode instruction is 0, the instruction can only reference locations in Sector 0. When S is 1, the instruction references locations relative to the current value of the program counter. The range of these relative locations is PC - '360 to PC + '377, inclusive.

Note that an R mode instruction that specifies a location in the range PC - '361 to PC - '400, inclusive, selects a special addressing code, such as stack register.

#### S Mode

Like R mode instructions, S mode instructions contain a sector bit. When S is 0, references are to Sector 0. When S is 1, however, references are <u>only</u> to those locations within the sector containing the instruction.

S mode is a holdover from early Prime machines that were based on the Honeywell 316 and 516 minicomputers. When operating in S mode, the 50 Series processors act exactly as these early machines do.

#### Summary of Addressing Modes

Table 1-1 summarizes addressing information about S, R, V, and I modes. For further information, see Chapter 3 of the <u>System Architecture</u> Reference Guide.

| Mode<br>                   | Address<br>  Length | Addressing Range                                                                                 | # Index <br>  Regs          | Indirection Levels |
|----------------------------|---------------------|--------------------------------------------------------------------------------------------------|-----------------------------|--------------------|
| 16S direct                 | 14 bits             | 1024 halfwords                                                                                   | l Once I                    | <b></b>  <br> <br> |
| 16S indirect               | 14 bits             | 16K halfwords                                                                                    | IOne I                      | Multiple           |
| 32S direct                 | 15 bits             | 1024 halfwords                                                                                   | One I                       |                    |
| 32S indirect               | 15 bits             | 32K halfwords                                                                                    | IOne I                      | Multiple (         |
| 32R direct                 | 15 bits             | 1008 halfwords                                                                                   | IOne I                      |                    |
| 32R indirect               | 15 bits             | 32K halfwords                                                                                    | ∣One I                      | Multiple           |
| 64R direct                 | 16 bits             | 1008 halfwords                                                                                   | IOne I                      |                    |
| 64R indirect               | 16 bits             | 64K halfwords                                                                                    | IOne I                      | One I              |
| 64V 16-bit<br>instructions | 16 bits             | 64K halfwords:<br>+256 SB relative<br>+256 LB relative<br>+/-256 PC relative<br>+512 PB absolute | One  <br>     <br>     <br> |                    |
| 64V 32-bit<br>instructions | 28 bits             | 4 segments*                                                                                      | Two  <br>                   | One I              |
| 64V indirect               | 28 bits             | 4096 segments*                                                                                   | ITWO I                      | One I              |
| 321 all                    | 28 bits             | 12 segments*<br>with GRR**                                                                       | Seven  <br>                 | One i              |
| 32I indirect               | 28 bits             | 4096 segments*                                                                                   | Seven I                     | One i              |

Table 1-1 Summary of Addressing Modes

\* All segments contain 128 Kbytes. \*\* Four segments for the 2250 and earlier processors because they have no GRR capability.

#### SUMMARY OF DATATYPES AND APPLICABLE INSTRUCTIONS

The 50 Series systems support several data representations. These representations fall into the major groups:

- Fixed-point data
- Floating-point numbers
- Decimal integers
- Character strings
- Queues

Tables 1-2 and 1-3 list the instructions applicable to the datatype operations (other than queues) available in S, R, V, and I modes. The body of each table shows which instructions perform a specific operation on a specific datatype. For detailed information about each instruction, refer to the instruction dictionaries in Chapters 2 and 3 of this manual. For further information about datatypes, see Chapter 6 of the System Architecture Reference Guide.

When using Tables 1-2 and 1-3, <u>as represents the set of arithmetic</u> conditions [EQ, GE, GT, LE, LT, NE]. Also, these tables do not include instructions that operate on CBIT, LINK, the condition codes, or queues.

Throughout the rest of this book, <u>R</u> is used to indicate a 32-bit I mode general register, while <u>r</u> indicates bits 1-16 of a 32-bit I mode general register. In addition, A and B represent the S and R mode 16-bit registers; L and E represent the V mode 32-bit registers.

|         |               |           |     | Table 1-2  |    |    |   |      |              |
|---------|---------------|-----------|-----|------------|----|----|---|------|--------------|
| Summary | $\mathbf{of}$ | Datatypes | and | Applicable | S, | R, | ۷ | Mode | Instructions |

| <br>  Operation               | S:                  | ize of         | Datat          | ype (ir      | n Bits            | of Reg          | ister)          | )            |
|-------------------------------|---------------------|----------------|----------------|--------------|-------------------|-----------------|-----------------|--------------|
| <br> <br>                     | 16<br>(A)           | 31<br> (A/B)   | 32<br>  (L)    | 64<br>(L/E)  | 32FP  <br>  (FAC) | 64FP (<br>DAC)  | 128FP <br>(QAC) | Dec  <br>(-) |
| Load from memory              | LDA                 | DLD            | LDL            |              | FLD               | DFLD            | QFLD            | XMV          |
| Store to memory               | STA                 | DST            | STL            |              | FST               | DFST            | QFST            |              |
| Add                           | ADD                 | DAD            |                |              | FAD               | DFAD            | QFAD            | XAD          |
| i Subtract                    | SUB                 | DSB            | SBL            |              | FSB               | DFSB            | QFSB            | XAD          |
| Multiply                      | MPY                 | 1              | MPL            |              | FMP               | DFMP            | QFMP            | XMP          |
| Divide                        | DIV                 | 1              |                | <br>         | FDV               | DFDV            | QFDV            | XDV          |
| Increment                     | IRS,<br>A1A,<br>A2A | <br> <br> <br> | <br> <br> <br> |              |                   | <br> <br> <br>  | <br> <br>       | <br> <br>    |
| <br>  Decrement<br>           | S1A,<br>S2A         | <br> <br>      | <br> <br>      |              |                   | <br> <br>       | 1               |              |
| AND                           | ANA                 | i<br>t         | ANL            |              |                   | 1<br> <br>      | 1               |              |
| OR                            | ORA                 | 1              | 1<br> <br>     |              |                   |                 | 1               | 1            |
| XOR I                         | ERA                 | <br> <br>      | ERL            | , ,<br>, , , |                   | ו<br> <br>      | 1               |              |
| Complement                    | CMA                 | •<br>•         | <br> <br>      |              | <br>              | 1               | 1               |              |
| Compare                       | CAS,<br>CAZ         | <br> <br>      |                |              | FCS               | DFCS            | QFC,<br>QFCS    | XCM          |
| Logical test                  | Laa                 | ,<br>          | LLaa           |              | LFaa              | LFaa            | 1               |              |
| Branch                        | Baa                 | 1              | BLaa           |              | BFaa              | BFaa            |                 | <br> <br>    |
| Logical left shift            | ALL                 | <br> <br>      | IJĴ            |              | 1                 |                 | 1               | 1            |
| Logical right shift           | ARL                 | •<br> <br>     | LRL            |              | <br> <br>         | 1               |                 | <br> <br>    |
| Arithmetic left shift         | ALS                 |                | LLS            |              | י<br> <br>ז       | r<br> <br>      | 1               |              |
| Arithmetic right  <br>  shift | ARS                 | I LRS          | LRS            |              | ,<br> <br>        | י<br> <br> <br> | 1               | <br>         |
| Rotate left shift             | ALR                 | 1              | LLR            |              |                   |                 | 1               |              |

\_\_\_\_

\_\_\_\_\_

|         |               | 9         | Cable | e 1-2 (conti | inue | æd) |   |      |              |    |
|---------|---------------|-----------|-------|--------------|------|-----|---|------|--------------|----|
| Summary | $\mathbf{of}$ | Datatypes | and   | Applicable   | S,   | R,  | V | Mode | Instructions | \$ |

\_\_\_\_\_

1

**r** 

| monstion                       | St        | ze of                 | Dataty    | vpe (ir      | Bits           | of Reg         | gister)          | <br>        |
|--------------------------------|-----------|-----------------------|-----------|--------------|----------------|----------------|------------------|-------------|
|                                | 16<br>(A) | 31<br>(A/B)           | 32<br>(L) | 64<br> (L/E) | 32FP<br>(FAC)  | 64FP<br>(DAC)  | 128FP1<br>(QAC)1 | Deci<br>(-) |
| Rotate right shift             | ARR       |                       | LRR       |              | 1              |                |                  | <br>        |
| Clear                          | CRA       | CRL                   | CRL       | CRLE         |                | 1              |                  |             |
| Clear left                     | CAL       | CRA                   | CRA       | CRL          |                | •<br>          |                  |             |
| Clear right                    | CAR       | CRB                   | CRB       | CRE          |                | 1<br> <br>1    |                  | 1           |
| Interchange halves             | ICA       | IAB                   | IAB       | ILE          |                | i<br> <br>1    |                  | 1           |
| Interchange and<br>clear left  | ICL       | XCA I                 | XCA       |              |                | 1<br> <br>     |                  |             |
| Interchange and clear right    | ICR       | XCB                   | XCB       | <br> <br>    |                | <br> <br> <br> |                  |             |
| Two's complement               | TCA       |                       | TCL       | !<br> <br>   | FCM            | DFCM           | QFCM             | י<br> <br>  |
| Set sign                       | SSM       | ISSM                  | SSM       |              |                | <br> <br>      |                  | י<br> <br>1 |
| Clear sign                     | SSP       | I SSP I               | SSP       |              | <br>           | 1<br>          | <br>   <br>      |             |
| Change sign                    | CHS       |                       | CHS       | 1            | 1              | ,<br> <br>,    | , ,<br>1  <br>1  | י<br> <br>  |
| Convert datatypes:             |           |                       |           | 1            | <br> <br>      | <br> <br>      |                  | י<br> <br>  |
| Integer to floating point      | FLTA      |                       | FLTL      | :<br> <br>   | י<br> <br>     | <br> <br>      |                  | <br> <br>   |
| Floating point to integer      | INTA      | 111/11  <br>    11/11 | INTL      | <br> <br>    | 1<br>1<br>1    | 1<br>1<br>1    | IQINQI<br>IQIQRI | 1<br> <br>  |
| Binary to decimal              | XBID      |                       | XBID      | XBID         | 1              | 1              |                  | י<br>ו<br>ו |
| Decimal to binary              | XDIB      | i  <br>i              | XDIB      | XDTB         | <br>           | 1              |                  | i<br>i      |
| Position for integer<br>divide | PIDA      | PID  <br>             | PIDL      | PIDL         | <br> <br> <br> | <br> <br>      |                  | 1<br> <br>  |
| Position after<br>multiply     | PIMA      |                       | PIML      |              | <br> <br>      | <br> <br>      |                  |             |
| Skips                          | Saa       |                       | I         | 1            | FSaa           | FSaa           | I                | 1           |

| <br>  Omoration  | Size of Datatype (in Bits of Regist |                    |                |                |               | Registe         | er)         |
|------------------|-------------------------------------|--------------------|----------------|----------------|---------------|-----------------|-------------|
|                  | 16  <br>  (r)                       | 32<br>(R)          | 64<br> (R/R+1) | 32FP<br>(FAC)  | 64FP<br>(DAC) | 128FP <br>(QAC) | Deci<br>(-) |
| Load from memory |                                     | L                  |                | FL             | DFL           | QFLD            | XMV         |
| Store to memory  | STH I                               | ST                 |                | FST            | DFST          | QFST            | 1           |
| Add              | I AH I                              | А                  | <br> <br>1     | FA             | DFA           | QFADI           | XAD         |
| Subtract         | ISH I                               | S                  | 1<br>          | FS             | DFS           | QFSB            | XAD         |
| Multiply         | MHI                                 | М                  | 1              | FM             | DFM           | QFMP            | XMP         |
| Divide           | IDH I                               | D                  |                | FDV            | DFDV          | QFDV            | XDV         |
| Increment        | IMH,  <br>IH1,  <br>IH2             | IM,<br>IR1,<br>IR2 | <br> <br> <br> | <br> <br> <br> |               |                 | <br> <br>   |
| Decrement        | DMH,  <br>DH1,  <br>DH2             | DM,<br>DR1,<br>DR2 | <br> <br> <br> |                |               | <br> <br>       | <br> <br>   |
| AND              | NH I                                | N                  | <br>           |                |               |                 |             |
| OR.              | OHI                                 | 0                  | <br>           |                |               |                 |             |
| XOR              | XH                                  | x                  | <br>           |                | <br> <br>     |                 |             |
| Complement       | CMH I                               | CMR                | !<br> <br>     |                | <br>          | 1               |             |
| Compare          | CHI                                 | С                  |                | FC             | DFC           | QFC,            | XCM         |
| Logical test     | LHaa                                | Laa                | <br>           | LFaa           | LFaa          |                 |             |
| Branch           | BHaal                               | BRaa               |                | BFaa           | BFaa          | 1               |             |
| Logical shift    |                                     | SHL                | <br>           |                |               |                 | <br> <br>   |
| Arithmetic shift |                                     | SHA                | <br> <br>      |                | י<br>ו        |                 | 1           |
| Shift right l    | SHR1                                | SR1                | 1<br>          |                | י<br>ו<br>ו   |                 |             |
| Shift right 2    | SHR2                                | SR2                | ,<br> <br>     |                | ו<br> <br>    |                 | 1           |
| Shift left 1     | SHL1                                | SL1                | <br>           | •<br>          |               | <br> <br>       | 1           |

Table 1-3 Summary of Datatypes and Applicable I Mode Instructions

Table 1-3 Summary of Datatypes and Applicable I Mode Instructions

| (monstion)                                         | Size           | of Da     | atatype         | (in Bit         | ts of l         | Registe                         | r)              |
|----------------------------------------------------|----------------|-----------|-----------------|-----------------|-----------------|---------------------------------|-----------------|
|                                                    | 16  <br>(r)    | 32<br>(R) | 64<br>(R/R+1)   | 32FP<br>  (FAC) | 64FP<br>(DAC)   | 128FP <br>  (QAC)               | Dec  <br>(-)    |
| Shift left 2                                       | SHL21<br>LHL21 | SL2       |                 |                 | <br>            |                                 | ,<br> <br> <br> |
| Shift left 3                                       | LHL3           |           |                 | <br>            | <br>            | <br>   <br>                     | <br>            |
| Rotate                                             |                | ROT       |                 | <br>            | <br>            | <br>   <br>                     | <br>            |
| Clear                                              | l              | CR        |                 | <br>            | ,<br> <br>      | , ,<br>   <br>                  | <br>            |
| Clear left                                         | CRBL           | CRHL      | •<br> <br>•     | 1               | 1<br>1          | , ,<br>   <br>                  | <br>            |
| Clear right                                        | CRBR           | CRHR      |                 | <br>            | <br>            | <br>                            | <br>            |
| Interchange halves                                 | IRB            | IRH       | I               | 1               | I               | <br>! !<br>! !                  | <br>            |
| Interchange and<br>clear left                      |                | ICHL      | ,<br> <br>      | <br>            | '<br> <br>      | <br>I I<br>I I                  | <br> <br>       |
| Interchange and clear right                        |                | ICHR      | •<br>           |                 | '<br> <br> <br> | , ,<br>, ,<br>, ,<br>, ,<br>, , | (<br>1          |
| Two's complement                                   | TCH            | TC        | ,<br> <br>      | I FCM           | I DFCM          | i QFCMI                         | <br>            |
| Set sign                                           | SSM            | SSM       | <br>            | <br>            | 1               | · · ·                           | <br>            |
| Clear sign                                         | SSP            | SSP       | •<br> <br>      |                 | <br>            |                                 | <br>            |
| Change sign                                        | CHS            | CHS       | ,<br> <br>      |                 | 1               |                                 | (               |
| Convert datatypes:<br>Integer to<br>floating point | FLTH           | FLT       | '<br> <br> <br> | <br> <br>       | ,<br> <br> <br> |                                 |                 |
| Floating point I<br>to integer                     | INTH           | INT       | '<br> <br> <br> |                 | ,<br> <br> <br> | I QINQI<br>I QIQRI              |                 |
| Binary to decimal                                  | XBID           | XBLD      | א<br>(עראבת) ו  | י<br>וכ<br>ו    | -<br> <br>      |                                 | 1               |
| Decimal to binary                                  | XDTB           | XDIB      |                 | 31<br>) 1       | <br>            |                                 |                 |
| Position for integer                               | PIDH           | PID       |                 |                 | 1<br>1          |                                 |                 |
| Position after multiply                            | PIMH           | PIM       | PIM             | i               | 1               | i i                             | 1               |

# 2 S, R, and V Mode

#### INTRODUCTION

This chapter contains descriptions for all 50 Series instructions used in S, R, and V modes. In the description of each instruction, you will find:

- The instruction mnemonic followed by any arguments.
- The name of the instruction.
- The bit format of the instruction.
- The modes for which the instruction is valid.
- Detailed information describing the instruction's action.
- Information about the how the instruction affects LINK, CBIT, and the condition codes.

#### Notation Conventions

Several abbreviations and symbols are used throughout this dictionary. Table 2-1 defines the dictionary notation.

| Table      | 2-1      |
|------------|----------|
| Dictionary | Notation |

| Symbol          | Meaning                                                                                                                                                                                                                                   |  |  |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| ,<br>  <b>A</b> | The A register.                                                                                                                                                                                                                           |  |  |  |
| ADDRESS         | Encompasses all the elements needed to specify an<br>effective address. This term is used because various<br>addressing types require you to specify the elements<br>in different orders (such as indirect or pre- and<br>post-indexing). |  |  |  |
| I AP            | Address pointer.                                                                                                                                                                                                                          |  |  |  |
| B<br>           | The 16-bit B register.                                                                                                                                                                                                                    |  |  |  |
| IBR.            | Base register.                                                                                                                                                                                                                            |  |  |  |
| I CB            | Class bits.                                                                                                                                                                                                                               |  |  |  |
|                 | Bit 1 of the keys.                                                                                                                                                                                                                        |  |  |  |
| I DAC           | The double precision floating-point accumulator with 48 bits of mantissa and 16 bits of exponent.                                                                                                                                         |  |  |  |
| Displace-       | The number of halfwords to be added to the base register  <br>to form the effective address.                                                                                                                                              |  |  |  |
| <b>E</b>        | The 32-bit E register.                                                                                                                                                                                                                    |  |  |  |
| EA              | Effective address.                                                                                                                                                                                                                        |  |  |  |
| F               | Floating-point accumulator.                                                                                                                                                                                                               |  |  |  |
| <b>FAC</b><br>  | The single precision floating-point accumulator with 48<br>bits of mantissa and 16 bits of exponent.                                                                                                                                      |  |  |  |
| FAR             | Field address register.                                                                                                                                                                                                                   |  |  |  |
| I FLR           | Field length register.                                                                                                                                                                                                                    |  |  |  |
| Halfword        | A 16-bit unit of memory.                                                                                                                                                                                                                  |  |  |  |
| I I             | Indirect bit.                                                                                                                                                                                                                             |  |  |  |
| <b>L</b>        | The 32-bit L register.                                                                                                                                                                                                                    |  |  |  |
| LINK            | Bit 3 of the keys. Not used in S and R modes.                                                                                                                                                                                             |  |  |  |
| Offset<br>      | The number of halfwords from the starting address of a segment.                                                                                                                                                                           |  |  |  |

#### Table 2-1 (continued) Dictionary Notation

| Symbol     | ŀ         | Meaning                                                                                         |  |  |  |  |  |
|------------|-----------|-------------------------------------------------------------------------------------------------|--|--|--|--|--|
| QAC        | <br> <br> | The quad precision floating-point accumulator with 96 bits of mantissa and 16 bits of exponent. |  |  |  |  |  |
| skip       |           | Skip next 16-bit halfword before continuing execution.                                          |  |  |  |  |  |
| Word       |           | A 32-bit unit of memory.                                                                        |  |  |  |  |  |
| X          | 1         | The X register (indexing).                                                                      |  |  |  |  |  |
| IXB        | 1         | Auxiliary base register.                                                                        |  |  |  |  |  |
| Y          | 1         | The Y register (indexing).                                                                      |  |  |  |  |  |
| n/m ∣      |           | Specifies the number of bits, $\underline{n}$ , occupied by field $\underline{m}$ .             |  |  |  |  |  |
| ;<br>; [ ] | <br> <br> | Specifies an optional argument.                                                                 |  |  |  |  |  |

#### Resumable Instructions

Some assembly language instructions are resumable. When an interrupt is requested during the execution of an instruction, the processor usually services the interrupt at the end of execution before starting the next instruction. Some instructions, however, are too long or too complex for this to be desirable. When an interrupt is requested during one of these resumable instructions, the processor preserves the state of the interrupted instruction, handles the interrupt, then resumes the instruction at the point where the interrupt occurred. Table 2-2 lists the resumable assembly language instructions.

#### Table 2-2 Resumable Instructions

| <br> <br> - | Instructions |      |      |      |  |  |  |
|-------------|--------------|------|------|------|--|--|--|
|             | ARGT         | XAD  | XBID | XCM  |  |  |  |
|             | XDTB         | XDV  | XED  | XMP  |  |  |  |
|             | XMV          | ZCM  | ZED  | ZFIL |  |  |  |
|             | ZMV          | ZMVD | ZTRN | STEX |  |  |  |

These instructions depend on the settings in certain registers to determine whether they are being executed for the first or another time. In addition, some registers may be used for intermediate storage, modifying the previous contents as a side effect. Registers so modified are noted per instruction description.

#### Storing Data Into the V and I Mode Instruction Stream

For the 6350 and 9750 to 9955 II, you must wait five instructions before executing data after any instruction that stores data into memory. If in doubt about the next five instructions (temporally) to be executed, use a mode change instruction to the current addressing mode, such as E64V, to allow the stored data to be executed. The rest of the 50 Series has no such restriction.

#### Instruction Formats

All S, R, and V mode instructions belong to one of the following instruction types:

- S and R Mode Memory Reference, Short
- V Mode Memory Reference, Short
- R Mode Memory Reference, Long
- V Mode Memory Reference, Long
- V Mode Generic AP (Address Pointer)
- S, R, and V Mode Generic Type A
- S, R, and V Mode Generic Type B
- S, R, and V Mode Shift
- S, R, and V Mode Skip

The format of each instruction type is shown in Figure 2-1.

Short and long memory reference instructions have an opcode in bits 3 to 6. The value of this opcode ranges from 1 to '17, inclusive, with the exception of '14, which is reserved for I/O. For opcode '15, the X bit is part of the opcode.

In addition, long memory reference instructions have an opcode extension contained in bits 13 to 14. Generic AP instructions have a generic A or B format (where bits 7 to 16 contain the opcode extension) followed by a 32-bit address pointer. Generic A and B, shift, and skip instructions are 16 bits long, all of which form an opcode. The values of bits 1 and 2 determine the basic instruction type: 11 for Generic A, 00 for Generic B, 01 for shifts, and 10 for skips. Bits 3 to 6 contain 0. Bits 7 to 16 contain an opcode extension. For shifts, bits 10 to 16 of the opcode extension contain the two's complement of the number of shifts to perform.

1 1 2 3 6 7 16 \_\_\_\_\_ | I | X | OP | DISPLACEMENT | \_\_\_\_\_ S and R Mode Memory Reference, Short 2 3 6 7 8 16 1 I I X OP I I I DISPLACEMENT I V Memory Mode Reference, Short 32 1 2 3 6 7 12 13 14 15 16 17 I I X I OPOODE I 110000 I OPEX I CB I [ OPTIONAL DISP ] I \_\_\_\_\_ R Mode Memory Reference, Long (Extended) Format 6 7 11 12 13 14 15 16 17 32 1 2 3 I I X I OPCODE I 11000 I Y I OPEX I BR I DISPLACEMENT I 33 48 I AUGMENT CODE\* \_\_\_\_\_ V Mode Memory Reference, Long Displacement Format + \*For quad operations only. \_\_\_\_\_

> S, R, and V Mode Instruction Formats Figure 2-1



S, R, and V Mode Instruction Formats Figure 2-1 (continued) INSTRUCTIONS

AlA Add 1 to A 1100001010000110 (S, R, V mode form)

Adds 1 to the contents of A and stores the result in A. If A initially contains  $(2^{**15})-1$ , an integer exception occurs and the instruction loads  $-(2^{**15})$  into A. If no integer exception occurs, the instruction resets CBIT to 0. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

A2A Add 2 to A 110000011000100 (S, R, V mode form)

Adds 2 to the contents of A and stores the result in A. If A initially contains  $(2^{**15})-1$  or  $(2^{**15})-2$ , an integer exception occurs and the instruction loads  $-(2^{**15})+1$  or  $-(2^{**15})$ , respectively, into A. If no exception occurs, the instruction resets CBIT to 0. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

ABQ address Add Entry to Bottom of Queue 1100001111001110 AP\32

(V mode form)

Adds the entry contained in A to the bottom of the queue referenced by the AP. (AP points to the queue's QCB.) Sets the condition codes to reflect EQ if the queue is full, or to NE if not full. Leaves the values of CBIT and LINK unchanged. See Chapters 6 and 11 of the <u>System</u> <u>Architecture Reference Guide</u> for more information about queues and queue operations.

#### ACA Add CBIT to A 1100001010001110 (S, R, V mode form)

Adds the value of CBIT to the contents of A and stores the result in A. If the initial value of A is  $(2^{**15})-1$  and CBIT is 1, the instruction loads  $-(2^{**15})$  into A and an integer exception occurs. If no integer exception occurs, the instruction resets CBIT to 0. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Note

This instruction adds CBIT to bit 16 of A.

ADD address
 Add
 I X 0 1 1 0 1 1 0 0 0 Y 0 0 BR\2 (V mode long)
 DISPLACEMENT\16

I X 0 1 1 0 1 1 0 0 0 0 0 0 CB\2 (R mode long) [ DISPLACEMENT\16 ]

IX0110DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Fetches the 16-bit contents of the location specified by EA and adds them to the contents of A. Stores the results in A.

If the resulting sum is less than or equal to  $(2^{**15})-1$  and greater than or equal to  $-(2^{**15})$ , the instruction resets CBIT to 0. If the sum is greater than or equal to  $2^{**15}$ , an integer exception occurs. If the sum is less than or equal to  $-(2^{**15})-1$ , an integer exception occurs.

When an integer exception occurs, the results are of the opposite sign of the correct answer. In addition, the 16 bits are the 16 LSBs of the correct answer, which needs 17 bits to be correctly represented.

If an integer exception occurs and bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

At the end of the operation, LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

ADL address Add Long IX011011000Y11ER\2 (V mode form) DISPLACEMENT\16

Calculates an effective address, EA. Fetches the 32-bit contents of the location specified by EA and adds them to the contents of L. Stores the results in L.

If the resulting sum is less than or equal to  $(2^{*}31)-1$  and greater than or equal to  $-(2^{*}31)$ , the instruction resets CBIT to 0. If the sum is greater than or equal to  $2^{*}31$ , an integer exception occurs. If the sum is less than or equal to  $-(2^{*}31)-1$ , an integer exception occurs.

When an integer exception occurs, the results are of the opposite sign of the correct answer. In addition, the 32 bits are the 32 LSBs of the correct answer (that needs 33 bits to be correctly represented).

If an integer exception occurs and bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

At the end of the operation, LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

ADLL Add LINK to L 110000100000000 (V mode form)

Adds the contents of LINK to the contents of L and stores the result in L. If the initial value of L is  $(2^{**31})-1$  and LINK is 1, an integer exception occurs. When an integer exception occurs, the results are of the opposite sign of the correct answer. In addition, the 32 bits are the 32 LSBs of the correct answer, which needs 33 bits to be correctly represented.

If no integer exception occurs, the instruction resets CBIT to 0. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Note

This instruction adds the value of LINK to bit 32 of L.

#### ALFA far Add L to FAR 00000101100F001 (V mode format)

Adds the two's complement value contained in L to the offset and bit number fields of FAR and stores the result in the specified FAR. Leaves the values of LINK and CBIT indeterminate. The values of the condition codes remain unchanged.

Figure 2-2 shows the format of L and the specified FAR for this instruction.



L and FAR Format for ALFA Figure 2-2

#### ALL n A Left Logical 0 1 0 0 0 0 1 1 0 0 N\6 (S, R, V mode form)

Shifts the contents of A left the appropriate number of bits, bringing zeros in through bit 16 as needed. CBIT and LINK contain the value of the last bit shifted out; the values of the other bits shifted out are lost. Leaves the values of the condition codes unchanged. See Chapter 6 of the System Architecture Reference Guide for more information about shifts.

N contains the two's complement of the number of shifts to perform. If N contains 0, the instruction performs 64 shifts. ALR n A Left Rotate 0 1 0 0 0 0 1 1 1 0 N\6 (S, R, V mode form)

Shifts the contents of A to the left, rotating bit 1 into bit 16. Stores the result in A. CBIT and LINK contain the value of the last bit rotated into bit 16. Leaves the values of the condition codes unchanged. See Chapter 6 of the <u>System Architecture Reference Guide</u> for more information about shifts.

N contains the two's complement of the number of shifts to perform. If N contains 0, the instruction performs 64 shifts.

ALS n A Arithmetic Left Shift 0100001101N\6 (S, R, V mode form)

Shifts the contents of A to the left, bringing zeros in on the right. Stores the result in A. If bit 1, the sign bit, changes state, the shift has resulted in a loss of significance and produces an integer exception. If no integer exception occurs, the instruction resets CBIT to 0. The value of LINK is indeterminate. Leaves the values of the condition codes unchanged. See Chapter 6 of the <u>System Architecture</u> Reference Guide for more information about shifts.

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

 ANA address AND to A
 IX 0 0 1 1 1 1 0 0 0 Y 0 0 BR\2 (V mode long)
 DISPLACEMENT\16
 IX 0 0 1 1 1 1 0 0 0 0 0 0 CB\2 (R mode long)

[ DISPLACEMENT\16 ]

IXOO11DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Logically ANDs the 16-bit contents of the location specified by EA with the contents of A, and stores the result in A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ANL address

AND to A Long  $I \times O O I I I I O O O Y I I BR \ge (V mode form)$ 

Calculates a 32-bit effective address, EA. Logically ANDs the 32-bit contents of the location specified by EA with the contents of L, and stores the result in L. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ARGT Argument Transfer 0000000110000101 (V mode form)

Transfers arguments from a source procedure to a destination procedure. ARGT is fetched and executed only when the argument transfer phase of a procedure call (PCL) instruction is interrupted or faulted.

To perform a procedure call and argument transfer, the source procedure must contain the PCL instruction followed by a number of argument templates. The destination procedure must begin with the ARGT instruction. When the PCL instruction is executed, control transfers to the destination procedure, and the ARGT instruction uses the templates to form the actual arguments. The arguments are stored in the new stack frame as they are computed. At the end of the ARGT instruction, the values of CBIT, LINK, and the condition codes are indeterminate.

ARGT must be the first executable instruction in any destination procedure that will use arguments. For those procedures whose entry control blocks specify zero arguments, you must omit ARGT or you will destroy the return pointer for PCL, producing indeterminate results.

For more information about argument transfers, refer to the section on procedure calls in Chapter 8 of the <u>System Architecture Reference</u> Guide.

ARL n A Right Logical 0 1 0 0 0 0 1 0 0 N\6 (S, R, V mode form)

Shifts the contents of A right the appropriate number of bits, bringing zeros in through bit 1. CBIT and LINK contain the value of the last bit shifted out; the values of the other bits shifted out are lost. Leaves the values of the condition codes unchanged.

N contains the two's complement of the number of shifts to perform. If N contains 0, the instruction performs 64 shifts. ARR n A Right Rotate 0 1 0 0 0 0 0 1 1 0 N\6 (S, R, V mode form)

Shifts the contents of A to the right, rotating bit 16 into bit 1. CBIT and LINK contain the value of the last bit rotated into bit 1. Leaves the values of the condition codes unchanged.

N contains the two's complement of the number of shifts to perform. If N contains 0, the instruction performs 64 shifts.

ARS n A Arithmetic Right Shift 0100000101N\6 (S, R, V mode form)

Shifts the contents of A to the right arithmetically, shifting copies of bit 1, the sign bit, into the vacated bits. CBIT and LINK contain the value of the last bit shifted out; the values of the other bits shifted out are lost. Leaves the values of the condition codes unchanged.

N contains the two's complement of the number of shifts to perform. If N contains 0, the instruction performs 64 shifts.

ATQ address Add Entry to Top of Queue 1100001111001111 (V mode form) AP\32

Adds the entry contained in A to the top of the queue referenced by the AP. (AP points to the queue's QCB.) Sets the condition codes to reflect EQ if the queue is full, or to NE if not full. Leaves the values of CBIT and LINK unchanged. For more information about queues and queue manipulation, see Chapters 6 and 11 of the <u>System</u> Architecture Reference Guide.

BCEQ address Branch on Condition Code EQ 1100001110000010 (V mode form) ADDRESS\16

If the condition codes reflect equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BOGE address Branch on Condition Code GE 1100001110000101 (V mode form) ADDRESS\16

If the condition codes reflect greater than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BOGT address Branch on Condition Code GT 110000111000001 (V mode form) ADDRESS\16

If the condition codes reflect greater than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BCLE address Branch on Condition Code LE 1100001110000000 (V mode form) ADDRESS\16

If the condition codes reflect less than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. BCLT address
 Branch on Condition Code LT
 1 1 0 0 0 0 1 1 1 0 0 0 0 1 0 0 (V mode form)
 ADDRESS\16

If the condition codes reflect less than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BCNE address Branch on Condition Code NE 1100001110000011 (V mode form) ADDRESS\16

If the condition codes reflect not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BCR address Branch on CBIT Reset to 0 1100001111000101 (V mode form) ADDRESS\16

If CBIT has the value 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If CBIT has the value 1, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BCS address Branch on CBIT Set to 1 1100001111000100 (V mode form) ADDRESS\16

If CBIT has the value 1, the instruction loads the specified address into the program counter. This address must be within the current segment. If CBIT has the value 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. BDX address Branch on Decremented X 1100000111011100 (V mode form) ADDRESS\16

Decrements the contents of X by one and stores the result in X. If the decremented value is not equal to 0, loads the specified address into the program counter. This address must be within the current segment. If the decremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BDY address Branch on D

Branch on Decremented Y 1100000111010100 (V mode form) ADDRESS\16

Decrements the contents of Y by one and stores the result in Y. If the decremented value is not equal to 0, loads the specified address into the program counter. This address must be within the current segment. If the decremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BEQ address Branch on A Equal to 0 1 1 0 0 0 0 1 1 0 0 0 1 0 1 0 (V mode form) ADDRESS\16

If the contents of A are equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the A contents are not equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged.

BFEQ address Branch on Floating Accumulator Equal to 0 1100001110001010 (V mode form) ADDRESS\16

If the contents of the floating accumulator are equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the floating accumulator contents are not equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged.

BFEQ works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the <u>System Architecture Reference</u> Guide.)

BFGE address Branch on Floating Accumulator Greater Than or Equal to 0 1100001110001101 (V mode form) ADDRESS\16

If the contents of the floating accumulator are greater than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the floating accumulator contents are less than 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LLNK and CBIT unchanged. BFGE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the <u>System</u> Architecture Reference Guide.)

BFGT address Branch on Floating Accumulator Greater Than 0 1100001110001001 (V mode form) ADDRESS\16

If the contents of the floating accumulator are greater than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the floating accumulator contents are less than or equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged. EFGT works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the <u>System</u> Architecture Reference Guide.)

BFLE address Branch on Floating Accumulator Less Than or Equal to 0 1100001110001000 (V mode form) ADDRESS\16

If the floating accumulator contents are less than or equal to 0, BFLE loads the specified address into the program counter. This address must be within the current segment. If the floating accumulator contents are greater than 0, execution continues with the next instruction. The condition codes contain the comparison result. (See Appendix A.) Leaves the values of LINK and CBIT unchanged. BFLE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

BFLT address Branch on Floating Accumulator Less Than 0 1100001110001100 (V mode form) ADDRESS\16

If the contents of the floating accumulator are less than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the floating accumulator contents are greater than or equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged. BFLT works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the <u>System</u> Architecture Reference Guide.)

BFNE address
 Branch on Floating Accumulator Not Equal to 0
 1 0 0 0 0 1 1 1 0 0 0 1 0 1 1 (V mode form)
 ADDRESS\16

If the contents of the floating accumulator are not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the floating accumulator contents are equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged. BFNE works correctly only on normalized or nearly normalized numbers because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

BGE address Branch on A Greater Than or Equal to 0 1100000110001101 (V mode form) ADDRESS\16

If the contents of A are greater than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the A contents are less than 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged. This instruction has the same operation as BLGE. BGT address Branch on A Greater Than 0 1100000110001001 (V mode form) ADDRESS\16

If the contents of A are greater than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the A contents are less than or equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged.

BIX address Branch on Incremented X 1100001011011100 (V mode form) ADDRESS\16

Increments the contents of X by one and stores the result in X. If the incremented value is not equal to 0, loads the specified address into the program counter. This address must be within the current segment. If the incremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BIY address Branch on Incremented Y 1100001011010100 (V mode form) ADDRESS\16

Increments the contents of Y by one and stores the result in Y. If the incremented value is not equal to 0, loads the specified address into the program counter. This address must be within the current segment. If the incremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BLE address Branch on A Less Than or Equal to 0 1100000110001000 (V mode form) ADDRESS\16

If the contents of A are less than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the A contents are greater than 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged.
BLEQ address Branch on L Equal to 0 1100000111000010 (V mode form) ADDRESS\16

If the contents of L are equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the L contents are not equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged.

BLGE address Branch on L Greater Than or Equal to 0 1100000110001101 (V mode form) ADDRESS\16

If the contents of L are greater than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the L contents are less than 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged. This instruction has the same operation as BGE.

BIGT address Branch on L Greater Than 0 1100000111000001 (V mode form) ADDRESS\16

If the contents of L are greater than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the L contents are less than or equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged.

BLLE address Branch on L Less Than or Equal to 0 1 1 0 0 0 0 0 1 1 1 0 0 0 0 0 0 (V mode form) ADDRESS\16

If the contents of L are less than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the L contents are greater than 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged. BLLT address Branch on L Less Than 0 1 1 0 0 0 0 0 1 1 0 0 0 1 1 0 0 (V mode form) ADDRESS\16

If the contents of L are less than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the L contents are greater than or equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged. This instruction has the same operation has BLT.

BLNE address Branch on L Not Equal to 0 1100000111000011 (V mode form) ADDRESS\16

If the contents of L are not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the L contents are equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged.

BLR address Branch on LINK Reset to 0 1100001111000111 (V mode form) ADDRESS\16

If LINK has the value 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If LINK has the value 1, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BLS address Branch on LINK Set to 1 1100001111000110 (V mode form) ADDRESS\16

If LINK has the value 1, the instruction loads the specified address into the program counter. This address must be within the current segment. If LINK has the value 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. BLT address Branch on A Less Than 0 1 1 0 0 0 0 0 1 1 0 0 0 1 1 0 0 (V mode form) ADDRESS\16

If the contents of A are less than O, the instruction loads the specified address into the program counter. This address must be within the current segment. If the A contents are greater than or equal to O, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged. This instruction has the same operation as BLLT.

EMEQ address Branch on Magnitude Condition EQ 1100001110000010 (V mode form) ADDRESS\16

If the condition codes indicate magnitude equal to 0, the instruction loads the specified address into the program counter, like BCEQ. EMEQ is intended for magnitude comparisons after a compare or subtract instruction. This address must be within the current segment. If the condition codes indicate some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EMGE address Branch on Magnitude Condition GE 1100001111000110 (V mode form) ADDRESS\16

If LINK has the value 1, the instruction loads the specified address into the program counter, like BLS. EMGE is used to determine if the magnitude of the A/L register quantity was greater than or equal to the memory quantity after a compare or subtract instruction. This address must be within the current segment. If LINK has the value 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. EMGT address Branch on Magnitude Condition GT 1100001111001000 (V mode form) ADDRESS\16

If LINK is 1 and the condition codes reflect not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If some other condition exists, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EMLE address Branch on Magnitude Condition LE 1100001111001001 (V mode form) ADDRESS\16

If LINK is 0 or the condition codes reflect equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If some other condition exists, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BMLT address Branch on Magnitude Condition LT 11000011110001111 (V mode form) ADDRESS\16

If LINK has the value 0, the instruction loads the specified address into the program counter, like BLR. EMLT is used to determine if the magnitude of the A/L register quantity is less than the memory quantity after a compare or subtract instruction. This address must be within the current segment. If LINK has the value 1, execution continues with the next instruction. Leaves the values of LINK, CBIT, and the condition codes unchanged.

EMNE address Branch on Magnitude Condition NE 1100001110000011 (V mode form) ADDRESS\16

If the condition codes indicate magnitude not equal to 0, the instruction loads the specified address into the program counter, like BCNE. EMNE is intended for magnitude comparisons after a compare or subtract instruction. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BNE address Branch on A Not Equal to 0 1 1 0 0 0 0 0 1 1 0 0 0 1 0 1 1 (V mode form) ADDRESS\16

If the contents of A are not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the A contents are equal to 0, execution continues with the next instruction. The condition codes contain the result of the comparison. (See Appendix A.) Leaves the values of LINK and CBIT unchanged.

CAL

Clear A Left Byte 1100001000101000 (S, R, V mode form)

Clears the left byte of A to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CALF address
Call Fault Handler
0 0 0 0 0 0 1 1 1 0 0 0 1 0 1 (V mode form)
AP\32

The address pointer in this instruction is to the ECB of a fault routine. The instruction uses this pointer to transfer control to the fault routine as if the transfer were a normal procedure call with no arguments passed. The values of CBIT, LINK, and the condition codes are indeterminate. See Chapter 10 of the <u>System Architecture Reference</u> Guide for more information.

CAR

Clear A Right Byte 1100001000100100 (S, R, V mode form)

Clears the right byte of A to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CAS address
Compare A and Skip
IX100111000Y00ER\2 (V mode long)
DISPLACEMENT\16

IX100111000000CB\2 (R mode long) [DISPLACEMENT\16]

IX1001DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. For 16-bit two's complement signed values only, compares the contents of the A register to the contents of the location specified by EA and skips as follows:

# ConditionSkipContents of A > contents of EA.No skip.Contents of A = contents of EA.Skip 16 bits (one halfword).Contents of A < contents of EA.</td>Skip 32 bits (two halfwords).

The value of CBIT is unchanged. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

CAZ Compare A With 0 110000010001100 (S, R, V mode form)

Compares the contents of A with 0. Skips as follows:

| Condition             | Lon Skip                      |  |
|-----------------------|-------------------------------|--|
| Contents of $A > 0$ . | No skip.                      |  |
| Contents of $A = 0$ . | Skip 16 bits (one halfword).  |  |
| Contents of $A < 0$ . | Skip 32 bits (two halfwords). |  |

The value of CBIT is unchanged. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

CEA Compute Effective Address 0000000001001001 (S, R mode form)

Interprets the contents of A as a 16-bit indirect address in the current addressing mode. Calculates an effective address, EA, from the indirect address and loads the final address into A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CGT Computed GOTO 0 0 0 0 0 1 0 1 1 0 0 1 1 0 0 (V mode form) INTEGER N\16 BRANCH ADDRESS 1\16 ...

BRANCH ADDRESS (N-1)\16

If the contents of A are greater than or equal to 1 and less than the specified integer N that follows the opcode, the instruction adds the contents of A to the contents of the program counter to form an address. (The program counter points to the integer N following the opcode.) Loads the contents of the location specified by this address into the program counter. If the contents of A are not within this range, the instruction adds integer N to the contents of the program counter and stores the result in the program counter. The values of CBIT, LINK, and the condition codes are indeterminate.

Second Edition

#### Note

Each of the branch addresses following the OGT instruction specifies a location within the current procedure segment.

# CHS

Change Sign 110000000010100 (S, R, V mode form)

Complements bit 1 of A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CLS address Compare L and Skip IX100111000Y11ER\2 (V mode form) DISPLACEMENT\16

Calculates an effective address, EA. For 32-bit two's complement signed values only, compares the contents of L to the contents of the 32-bit location specified by EA and skips as follows.

| Condition |                        |           | Skip                          |
|-----------|------------------------|-----------|-------------------------------|
|           | Contents of L > conter | ts of EA. | No skip.                      |
|           | Contents of L = conten | ts of EA. | Skip 16 bits (one halfword).  |
|           | Contents of L < conter | ts of EA. | Skip 32 bits (two halfwords). |

The value of CBIT is unchanged. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

# CMA

Complement A

11000010000001 (S, R, V mode form)

Forms the one's complement of the contents of A by inverting the value of each bit, and stores the result in A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CRA

Clear A to O

11000000010000 (S, R, V mode form)

Clears the contents of A to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CRB

Clear B to 0 110000000001101 (S, R, V mode form) 110000000001100

Clears the contents of B to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

Opcode '140014 executes both a CRB and a FDBL. This is a conversion aid for P300 programs. This opcode should not be used; it is implemented for compatibility's sake only.



Clear E to 0 1100001100000100 (V mode form)

Clears the contents of E to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CRL Clear L to 0 1 1 0 0 0 0 0 0 0 0 0 1 0 0 0 (S, R, V mode form)

Clears the contents of L to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CRLE Clear L and E to 0 1 1 0 0 0 0 1 1 0 0 0 0 1 0 0 0 (V mode form)

Clears the contents of E and L to O. Leaves the values of LINK, CBIT, and the condition codes unchanged.

CSA Copy Sign of A 1 1 0 0 0 0 0 1 1 0 1 0 0 0 0 (S, R, V mode form)

1

Sets CBIT equal to the value of bit 1 of A and clears bit 1 of A to 0. The value of LINK is indeterminate. Leaves the values of the condition codes unchanged.

DAD address Double Add IX011011000000CB\2 (R mode long) [DISPLACEMENT\16]

IX0110DISPLACEMENT\10 (S, R mode form)

Calculates an effective address, EA. Fetches the 31-bit contents of the location specified by EA and adds them to the 31-bit contents of A and B. Stores the result in A and B.

If the result is greater than or equal to  $2^{**30}$ , an integer exception occurs and the instruction loads bit 1 of A with a 1, and bits 2 to 16 of A and bits 2 to 16 of B with (result -  $(2^{**30})$ ). Bit 1 of B contains 0.

If the result is less than  $-(2^{*30})$ , an integer exception occurs and the instruction loads bit 1 of A with a 0 and bits 2 to 16 of A and bits 2 to 16 of B with the negative of (result +  $(2^{*30})$ ). Bit 1 of B contains 0.

If no integer exception occurs, CBIT is reset to 0. At the end of the instruction, LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Notes

1. Bit 17 of each 31-bit integer must be 0. If nonzero, unpredictable results will occur.

2. This instruction executes in double precision mode only.

## DBL

Enter Double Precision Mode 0000000000000111 (S, R mode form)

Enters double precision mode by setting bit 2 of the keys to 1. Subsequent LDA, STA, ADD, and SUB instructions manipulate 31-bit integers and are interpreted as DLD, DST, DAD, and DSB, respectively. Leaves the values of CBIT, LINK, and the condition codes unchanged. In V or I mode, bit 2 of the keys has no effect. DFAD address Double Precision Floating Add IXOIIOIIOOYIOER\2 (V mode long) DISPLACEMENT\16

I X O 1 1 O 1 1 O O O O 1 O CB\2 (R mode long) [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Adds the double precision number in the location specified by EA to the 64-bit contents of the DAC. (See Chapter 6 of the <u>System Architecture Reference Guide</u> for more information.) Normalizes the result and loads it into the DAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

For 750 and 850 processors, exponent underflow is detected, but exponent overflow is not.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

DFCM Double Precision Floating Complement 1100000101111100 (R, V mode form)

Forms the two's complement of the double precision number in the DAC and normalizes it if necessary. (See Chapter 6 of the <u>System</u> <u>Architecture Reference Guide</u>.) Stores the result in the DAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

DFCS address
Double Precision Floating Point Compare and Skip
I X 1 0 0 1 1 1 0 0 0 Y 1 0 BR\2 (V mode long)
DISPLACEMENT\16

I X 1 0 0 1 1 1 0 0 0 0 1 0 CB (R mode long)[ DISPLACEMENT(16 ]

Calculates an effective address, EA. Compares the DAC contents (see Chapter 6 of the <u>System Architecture Reference Guide</u>) to the contents of the 64-bit location specified by EA and skips as follows.

| Condition                   | Skip                          |
|-----------------------------|-------------------------------|
| DAC contents > EA contents. | No skip.                      |
| DAC contents = EA contents. | Skip 16 bits (one halfword).  |
| DAC contents < EA contents. | Skip 32 bits (two halfwords). |

The values of CBIT, LINK, and the condition codes are indeterminate. On some processors, DFCS works correctly only on normalized numbers as follows. The comparison has a maximum of three sequential stages: first the signs, then the exponents, and finally the fractions of the two numbers are compared for equality. If the comparison during any one of these stages reveals an inequality, the results are returned and the instruction ends. Unnormalized numbers are unexpected and produce unexpected results. Other processors actually perform a subtract operation, resulting in a proper comparison.

DFDV address
Double Precision Floating Point Divide
IX111111000Y10 ER\2 (V mode long)
DISPLACEMENT\16
IX111111000010CB\2 (R mode long)

[ DISPLACEMENT\16 ]

Calculates an effective address, EA. Divides the contents of the DAC by the contents of the location specified by EA. (See Chapter 6 of the <u>System Architecture Reference Guide.</u>) Normalizes the result and stores the whole quotient in the DAC. An overflow or a divide by 0 causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide.

DFLD address
Double Precision Floating Point Load
I X 0 0 1 0 1 1 0 0 0 Y 1 0 ER\2 (V mode long form)
DISPLACEMENT\16
I X 0 0 1 0 1 1 0 0 0 0 1 0 CE\2 (R mode long form)

[ DISPLACEMENT\16 ]

Calculates an effective address, EA. Loads the 64-bit contents of the location specified by EA into the DAC. (See Chapter 6 of the System Architecture Reference Guide.) Leaves the values of LINK, CBIT, and the condition codes unchanged.

#### Note

This instruction does not normalize the result before loading it into the DAC.

DFLX address Double Precision Floating Point Load Index I 0 1 1 0 1 1 1 0 0 0 Y 1 0 ER\2 (V mode long) DISPLACEMENT\16

I0110111000010CB\2 (R mode long) [DISPLACEMENT\16]

Calculates an effective address, EA. Loads the index register, X, with four times the 16-bit contents of the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

DFLX cannot do indexing. See Appendix B for more information.

DFMP address Double Precision Floating Point Multiply I X 1 1 1 0 1 1 0 0 0 Y 1 0 BR\2 (V mode long) DISPLACEMENT\16

 $I X 1 1 1 0 1 1 0 0 0 0 1 0 CB \ (R mode long)$ [ DISPLACEMENT \16 ]

Calculates an effective address, EA. Multiplies the contents of the DAC by the 64-bit contents of the location specified by EA. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Normalizes the result, if necessary, and stores it in the DAC. An overflow causes a floating-point exception; if none occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the DFMP instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

DFSB address Double Precision Floating Point Subtract I X 0 1 1 1 1 1 0 0 0 Y 1 0 BR\2 (V mode long) DISPLACEMENT\16

I X 0 1 1 1 1 1 0 0 0 0 1 0 CB (R mode long)[ DISPLACEMENT(16 ]

Calculates an effective address, EA. Subtracts the 64-bit contents of the locations specified by EA from the contents of the DAC. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Loads the result in the DAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

For 750 and 850 processors, exponent underflow is detected, but exponent overflow is not.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

DFST address Double Precision Floating Point Store IX010011000Y10ER\2 (V mode long) DISPLACEMENT\16

 $I X O 1 O O 1 1 O O O 1 O CB \ (R mode long)$ [DISPLACEMENT\16]

Calculates an effective address, EA. Stores the contents of the DAC into the location specified by EA. (See Chapter 6 of the System Architecture Reference Guide.) Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This instruction does not normalize the result before loading it into the specified memory location. DIV address Divide IX111111000000CB\2 (R mode long) [DISPLACEMENT\16]

IX1111DISPLACEMENT\10 (S mode; R mode short)

Calculates an effective address, EA. Divides the 31-bit contents of A and B by the 16-bit contents of the location specified by EA. Stores the 16-bit quotient in A and the 16-bit remainder in B. The sign of the remainder equals the sign of the dividend.

Overflow occurs when the quotient is less than  $-(2^{**15})$  or greater than  $(2^{**15})-1$ . An overflow or a divide by 0 causes an integer exception. If no integer exception occurs, CBIT is reset to 0. This instruction leaves the values of LINK and the condition codes indeterminate.

If an integer exception occurs when bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

DIV address Divide IX11111000Y00BR\2 (V mode long) DISPLACEMENT\16

IXIIIIDISPLACEMENT\10 (V mode short)

Calculates an effective address, EA. Divides the contents of L by the 16-bit contents of the location specified by EA. Stores the 16-bit quotient in A and the 16-bit remainder in B. The sign of the remainder equals the sign of the dividend.

When the quotient is less than  $-(2^{**15})$  or greater than  $(2^{**15})-1$ , an overflow occurs, causing an integer exception. A divide by 0 also causes an integer exception. If no integer exception occurs, CBIT is reset to 0. This instruction leaves the values of LINK and the condition codes indeterminate.

If the integer exception occurs when bit 8 of the keys is 0, the instruction sets CBIT to 1. If bit 8 is 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

DLD address Double Load I X 0 0 1 0 1 1 0 0 0 0 0 CB\2 (R mode long) [ DISPLACEMENT\16 ]

I X 0 0 1 0 DISPLACEMENT\10 (S mode; R mode short)

Calculates an effective address, EA. Loads the 16-bit contents of the location specified by EA into A, and the 16-bit contents of the location specified by EA+1 into B. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This instruction executes only in double precision mode.

DRN Double Round From Quad 010000011000000 (V mode form)

Converts the value in QAC to a double precision floating-point number. If QAC contains 0, the instruction ends. If bits 50 to 96 of QAC are not 0, or bit 48 of QAC contains 1, the instruction adds the value of bit 49 to that of bit 48 (unbiased round) and clears bits 49 to 96 of QAC to 0. If any other condition exists, no unbiased rounding occurs but bits 49 to 96 of QAC are still cleared to 0. After any rounding and clearing occurs, the instruction normalizes the result and loads it into bits 1 to 64 of QAC.

If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

Note

If DRN is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.) DRNM

Double Round From Quad Towards Negative Infinity 1100000101111001 (V mode form)

Converts the value in QAC to a double precision floating-point number. If QAC contains 0, the instruction ends. If bits 49 to 96 of QAC contain zeros, the instruction ends. In any other case, the instruction clears bits 49 to 96 to 0, normalizes the result, and places it in bits 1 to 64 of QAC.

The value of CBIT is unchanged. The values of LINK and the condition codes are indeterminate.

Note

If DRNM is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

DRNP

Double Round From Quad Towards Positive Infinity 010000011000001 (V mode form)

Converts the value in QAC to a double precision floating-point number. If QAC contains 0, the instruction ends. If bits 49 to 96 of QAC contain zeros, the instruction ends. In any other case, the instruction adds 1 to the value contained in bit 48 of QAC, clears bits 49 to 96 to 0, the instruction normalizes the result and places it in bits 1 to 64 of QAC.

If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

Note

If DRNP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

DRNZ Double Round From Quad Towards Zero 0 1 0 0 0 0 0 1 1 0 0 0 0 1 0 (V mode form)

Converts the value in QAC to a double precision floating-point number. If QAC contains 0, the instruction ends. If bits 49 to 96 of QAC contain zeros and bit 1 contains 1, the instruction adds 1 to the value contained in bit 48 of QAC, clears bits 49 to 96 to 0, normalizes the result and places it in bits 1 to 64 of QAC. If any other condition exists, no rounding occurs.

If no floating-point exception occurs, the instruction resets CBIT to O. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Note

If DRNZ is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

DRX Decrement and Replace X 110000010001000 (S, R, V mode form)

Decrements the contents of X by 1 and stores the result in X. Skips the next memory location if the decremented value is 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

DSB address Double Subtract IX01111100000CB\2 (R mode long) [DISPLACEMENT\16]

IX0111DISPLACEMENT\10 (S mode; R mode short)

Calculates an effective address, EA. Fetches the 31-bit integer contained in the locations specified by EA and EA+1 and subtracts it from the 31-bit integer contained in A and B. Stores the result in A and B.

If the result is greater than or equal to  $2^{**30}$ , an integer exception occurs and the DSB instruction loads bit 1 of A with 1, and bits 2 to 16 of A and 2 to 16 of B with the absolute value of (result -  $(2^{**30})$ ). Bit 1 of B must be 0.

If the result is less than  $-(2^{*}30)$ , an integer exception occurs and the instruction loads bit 1 of A with a 0, and bits 2 to 16 of A and bits 2 to 16 of B with the negative of (result +  $(2^{*}30)$ ). Bit 1 of B must be 0.

If no integer exception occurs, CBIT is reset to 0. At the end of the instruction, LINK contains the borrow bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Notes

- 1. Bit 17 of each 31-bit integer must be 0 or indeterminate results occur.
- 2. This instruction executes in double precision mode only.
- 3. To negate a 31-bit integer, subtract it from 0.

# DST address

Double Store I X 0 1 0 0 1 1 0 0 0 0 0 0 CB\2 (R mode long) [ DISPLACEMENT\16 ]

I X 0 1 0 0 DISPLACEMENT\10 (S mode; R mode short)

Calculates an effective address, EA. Stores the contents of A at the location specified by EA, and the contents of B at the location specified by EA+1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This instruction executes only in double precision mode.

DVL address Divide Long IX11111000Y11ER\2 (V mode long) DISPLACEMENT\16

Calculates an effective address, EA. Divides the 64-bit contents of L and E by the 32-bit contents of the location specified by EA. Stores the quotient in L and the remainder in E. An overflow or divide by O causes an integer exception. If no integer exception occurs, CBIT is reset to O. The values of LINK and the condition codes are indeterminate.

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Note

This note applies only to the 150/250, 450/550/250-II, I450-II, and 2250 processors. When the value '040000 '000000 '000000 '000000 is divided by '100000 '000000, the quotient overflows the hardware (and sets the CBIT to 1) in the early stage of the algorithm even though the final result is not in overflow ('100000 '000000). E16S Enter 16S Mode 0000000000001001 (S, R, V mode form)

Sets bits 4 to 6 of the keys to 000. Subsequent S mode instructions may now be interpreted, and 16S address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

► E32I

Enter 32I Mode 000000100001000 (S, R, V mode form)

Sets bits 4 to 6 of the keys to 100. Subsequent I mode instructions may now be interpreted, and 32I address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

**E32R** 

Enter 32R Mode 00000100001011 (S, R, V mode form)

Sets bits 4 to 6 of the keys to 011. Subsequent R mode instructions may now be interpreted, and 32R address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

**E32S** 

Enter 32S Mode 0000000000001011 (S, R, V mode form)

Sets bits 4 to 6 of the keys to 001. Subsequent S mode instructions may now be interpreted, and 32S address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

**E64**R

Enter 64R Mode 000000100001001 (S, R, V mode form)

Sets bits 4 to 6 of the keys to 010. Subsequent R mode instructions may now be interpreted, and 64R address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

► E64V Enter 64V Mode 

Sets bits 4 to 6 of the keys to 110. Subsequent V mode instructions may now be interpreted, and 64V address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EAA address Effective Address to A I X 0 0 0 1 1 1 0 0 0 0 0 1 CB (R mode form)DISPLACEMENT\16

Calculates an effective address, EA, and loads it into A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EAFA far, address Effective Address to FAR 00000101100FAR0000 (V mode form)  $AP \setminus 32$ 

Builds a 36-bit EA from the 32-bit address pointer contained in the instruction and loads it into the specified FAR. The AP bit field is processed and loaded into the bit portion of the FAR for direct access; indirection uses the bit field in the indirect pointer (if any). Leaves the values of CBIT, LINK, and the condition codes unchanged.

Figure 2-3 shows the format of the EA loaded into the specified FAR.

1 16 17 32 33 36 | RING, SEG | WORD # | BIT # 1

> EA Format for EAFA Figure 2-3

EAL address Effective Address to L I X 0 0 0 1 1 1 0 0 0 Y 0 1 BR 2 (V mode form) DISPLACEMENT\16

Calculates an effective address, EA, and loads it into L. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EALB address Effective Address to LB IX101111000Y10BR\2 (V mode form) DISPLACEMENT\16

Calculates an effective address, EA, and loads it into LB. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EAXB address Effective Address to XB IXI01011000Y10BR\2 (V mode form) DISPLACEMENT\16

Calculates an effective address, EA, and loads it into XB. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EIO address Execute I/O I 0 1 1 0 0 1 1 0 0 0 Y 0 1 ER\2 (V mode form) DISPLACEMENT\16

Calculates an effective address, EA. Executes bits 17 to 32 of EA as if the bits were an extended PIO instruction. If execution is successful, the instruction sets the condition codes as follows:

- OC Meaning
- EQ Successful INA, OTA, or SKS instruction
- NE Unsuccessful INA, OTA, or SKS; all OCP

Leaves the values of LINK and CBIT unchanged. See Chapter 11 of the System Architecture Reference Guide for more information.

#### Note

This is a restricted instruction.

ENB

Enable Interrupts 00000010000001 (S, R, V mode form)

Enables interrupts by setting bit 1 of the modals to 1. Interrupts remain inhibited for the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

#### ENB is a restricted instruction.

ENBL Enable Interrupts (Local) 00000010000001 (S, R, V mode form)

This 850 instruction performs the same actions as ENB except that it is performed specifically for the local processor. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

ENBL is a restricted instruction.

ENEM Enable Interrupts (Mutual) 0000001000000 (S, R, V mode form)

For the 850, a processor checks the availability of the mutual exclusion lock. If available, the processor releases this lock and enables interrupts. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This is a restricted instruction.

ENBP Enable Interrupts (Process) 0 0 0 0 0 0 1 0 0 0 0 0 1 0 (S, R, V mode form)

For the 850, a processor checks the availability of the process exchange lock. If available, the processor releases this lock and enables interrupts. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

#### This is a restricted instruction.

Second Edition

ERA address
Exclusive OR to A
I X 0 1 0 1 1 1 0 0 0 Y 0 0 ER\2 (V mode long)
DISPLACEMENT\16
I X 0 1 0 1 1 1 0 0 0 0 0 0 CE\2 (R mode long)
[ DISPLACEMENT\16 ]
I X 0 1 0 1 DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Exclusively ORs the contents of the location specified by EA and the contents of A. Stores the results in A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ERL address Exclusive Or to L IX010111000Y11ER\2 (V mode long) DISPLACEMENT\16

Calculates an effective address, EA. Exclusively ORs the contents of L with the contents of the 32-bit location specified by EA. Stores the results in L. Leaves the values of CBIT, LINK, and the condition codes unchanged.

FAD address
Floating Point Add
I X 0 1 1 0 1 1 0 0 0 Y 0 1 ER\2 (V mode long)
DISPLACEMENT\16
I X 0 1 1 0 1 1 0 0 0 0 0 1 CB\2 (R mode long)
[ DISPLACEMENT\16 ]

Calculates an effective address, EA. Adds the contents of the location specified by EA to the contents of the FAC. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Stores the result in the FAC and normalizes it if necessary. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

FCDQ

Floating Point Convert Double to Quad 1100000101111001 (V mode form)

Clears FAC1 to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

If FCDQ is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

FCM Floating Point Complement 1100000101011000 (R, V mode form)

Forms the two's complement of the FAC mantissa and normalizes the result if necessary. (See Chapter 6 of the System Architecture Reference Guide.) Stores the result in the FAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide.

FCS address Floating Point Compare and Skip I X 1 0 0 1 1 1 0 0 0 Y 0 1 ER\2 (V mode long) DISPLACEMENT\16

I X 1 0 0 1 1 1 0 0 0 0 0 1 CB (2 (R mode long))[ DISPLACEMENT (16 ]

Condition

Calculates an effective address, EA. In rounding mode, the instruction rounds the contents of DAC, then compares the rounded value to the contents of the memory location specified by EA. In normal mode, no rounding occurs before the compare. (See Chapter 6 of the <u>System</u> <u>Architecture Reference Guide</u> for more information.) The compare results in a skip as follows:

|                             | <b>_</b>                     |
|-----------------------------|------------------------------|
| FAC contents > EA contents. | No skip.                     |
| FAC contents = EA contents. | Skip 16 bits (one halfword). |
| FAC contents < EA contents. | Skip 32 bits (two halfwords) |

Skin

The values of CBIT, LINK, and the condition codes are indeterminate.

On some processors, FCS works correctly only on normalized numbers as follows. The comparison has a maximum of three sequential stages: first the signs, then the exponents, and finally the fractions of the two numbers are compared for equality. If the comparison during any one of these stages reveals an inequality, the results are returned and the instruction ends. Unnormalized numbers are unexpected and produce unexpected results. Other processors actually perform a subtract, resulting in a proper comparison.

FDBL Floating Point Convert Single to Double 1100000000001110 (V mode form)

Converts the single precision floating-point number in the floating accumulator to a double precision floating-point number by loading zeros into bits 33 to 48 of the floating accumulator. Leaves the values of CBIT, LINK, and the condition codes unchanged.

FDV address Floating Point Divide IX111111000Y01ER\2 (V mode long) DISPLACEMENT\16 IX111111000001CB\2 (R mode long) [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Divides the contents of the FAC by the contents of the location specified by EA. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Normalizes the result if necessary and stores it in the FAC. A divide by 0 or an overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

Note

The location specified by EA must contain a normalized floating-point number. An unnormalized divisor can cause an error.

FLD address
Floating Point Load
I X 0 0 1 0 1 1 0 0 0 Y 0 1 BR\2 (V mode long)
DISPLACEMENT\16

I X 0 0 1 0 1 1 0 0 0 0 0 1 CB\2 (R mode long) [ DISPLACEMENT\16 ]

Calculates a 32-bit effective address, EA. Loads the 32-bit contents in the location specified by EA into the FAC without normalizing. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Leaves the values of LINK, CBIT, and the condition codes unchanged.

FLOT Convert Integer to Floating Point 1100000101101000 (R mode form)

Converts the 31-bit integer contained in A and B to a normalized floating-point number and stores the result in the floating accumulator. The values of CBIT, LINK, and the condition codes are indeterminate.

Second Edition

FLTA Convert Integer to Floating Point 1100000101011010 (V mode form)

Converts the 16-bit integer in A to a floating-point number and stores the result in the floating accumulator. The values of CBIT, LINK, and the condition codes are indeterminate.

FLTL

Convert Long Integer to Floating Point 1100000101011101 (V mode form)

Converts the 32-bit integer in L to a floating-point number and stores the result in the floating accumulator. The values of CBIT, LINK, and the condition codes are indeterminate.

 FLX address Floating Load Index I0110111000Y01BR\2 (V mode long) DISPLACEMENT\16 I 0 1 1 0 1 1 1 0 0 0 0 0 1 CB\2 (R mode long) [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Loads the index register, X, with two times the 16-bit contents of the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

FLX cannot do indexing. See Appendix B for more information.

 FMP address Floating Point Multiply IX111011000Y01BR\2 (V mode long) DISPLACEMENT\16

IX111011000001CB\2 (R mode long) [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Multiplies the contents of the FAC by the contents of the location specified by EA. (See Chapter 6 of the System Architecture Reference Guide.) Normalizes the result if necessary and stores it in the FAC. An overflow causes а floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the FMP instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

FRN Floating Point Round 1100000101011100 (R, V mode form)

This instruction operates on and stores all results in the floating accumulator.

For the 2350 to the 9955 II, the following actions occur. If bits 1 to 48 contain 0, then bits 49 to 64 are cleared to 0. If bits 24 and 25 both contain 1, then 1 is added to bit 24, bits 25 to 48 are cleared to 0, and the result is normalized. If bit 25 contains 1 and bits 26 to 48 are not equal to 0, then 1 is added to bit 24, bits 25 to 48 are cleared, and the result is normalized.

For the earlier systems listed in "About This Book", the following actions occur. If bits 1 to 48 contain 0, then bits 49 to 64 are cleared to 0. Otherwise, bit 25 is added to bit 24, bits 25 to 48 are cleared to 0, and the result is normalized.

For all systems, if no floating point exception occurs, sets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

FRNM FLoating Point Round Towards Negative Infinity 010000011010000 (V mode form)

Converts the 64-bit value in DAC to a single precision floating-point number. If DAC contains 0, the instruction ends. If bits 25 to 48 of DAC contain zeros, the instruction ends. In any other case, the instruction clears bits 25 to 48 to 0, normalizes the result, and places it in DAC. If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. (See Chapter 10 of the System Architecture Reference Guide.)

FRNP Floating Point Round Towards Positive Infinity 0 1 0 0 0 0 0 0 1 1 0 0 0 0 1 1 (V mode form)

Converts the 64-bit value in DAC to a single precision floating-point number. If DAC contains 0, the instruction ends. If bits 25 to 48 of DAC contain zeros, the instruction ends. In any other case, the instruction adds 1 to the value contained in bit 24 of DAC, clears bits 25 to 48 to 0, normalizes the result, and places it in DAC.

If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

FRNZ Floating Point Round Towards Zero 010000011010001 (V mode form)

Converts the 64-bit value in DAC to a single precision floating-point number. If DAC contains 0, the instruction ends. If bits 25 to 48 of DAC are not zeros and bit 1 contains 1, the instruction adds 1 to the value contained in bit 24 of DAC, clears bits 25 to 48 to zero, normalizes the result, and places it in DAC. If any other condition exists, no rounding occurs.

If no floating-point exception occurs, the instruction resets CBIT to O. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

FSB address
Floating Point Subtract
I X 0 1 1 1 1 1 0 0 0 Y 0 1 BR\2 (V mode long)
DISPLACEMENT\16
I X 0 1 1 1 1 1 0 0 0 0 0 1 CB\2 (R mode long)
[ DISPLACEMENT\16 ]

Calculates an effective address, EA. Subtracts the 32-bit contents of the locations specified by EA from the contents of the FAC. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Normalizes the result if necessary and stores it in the FAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the FSB instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

FSGT Floating Point Skip on F Greater Than 0 1100000101001101 (R. V mode form)

Skips the next 16-bit halfword if the contents of the floating accumulator are greater than 0. Leaves the value of LINK and CBIT unchanged. The values of the condition codes are indeterminate. FSGT works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

FSLE

Floating Point Skip on F Less Than or Equal to 0 1100000101000 (R. V mode form)

Skips the next 16-bit halfword if the contents of the floating accumulator are less than or equal to 0. Leaves the values of LINK and CBIT unchanged. The values of the condition codes are indeterminate. FSLE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

FSMI Floating Point Skip on F Minus 1100000101001010 (R, V mode form)

Skips the next 16-bit halfword if the contents of the floating accumulator are less than 0. Leaves the values of LINK and CBIT unchanged. The values of the condition codes are indeterminate. FSMI works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

FSNZ Floating Point Skip on F Not 0 1100000101001001 (R, V mode form)

Skips the next 16-bit halfword if the contents of the floating accumulator are less than or equal to 0. Leaves the values of LINK and CBIT unchanged. The values of the condition codes are indeterminate. FSNZ works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

FSPL Floating Point Skip on FAC Plus 1100000101001011 (R, V mode form)

Skips the next 16-bit halfword if the contents of the floating accumulator are greater than or equal to 0. Leaves the values of LINK and CBIT unchanged. The values of the condition codes are indeterminate. FSPL works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

FST address
Floating Point Store
I X 0 1 0 0 1 1 0 0 0 Y 0 1 ER\2 (V mode long)
DISPLACEMENT\16
I X 0 1 0 0 1 1 0 0 0 0 0 1 CB\2 (R mode long)

[ DISPLACEMENT\16 ]

Calculates an effective address, EA. Stores the contents of the FAC into the 32-bit location specified by EA. (See Chapter 6 of the System Architecture Reference Guide.) If the exponent contained in the FAC is too large to be expressed in 8 bits, a floating-point exception (store

exception) occurs. If no floating-point exception occurs, the instruction resets CBIT to 0. At the end of the instruction, the values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information. In either case, a floating-point exception leaves the contents of the memory location in an indeterminate state.

This instruction does not normalize the result before loading it into the specified memory location unless rounding is enabled.

FSZE Floating Point Skip on F Equal to 0 11000001010000 (R, V mode form)

Skips the next 16-bit halfword if the contents of the floating accumulator equal O. Leaves the values of LINK and CBIT unchanged. The values of the condition codes are indeterminate. FSZE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

# 

Halts computer operation. The program counter points to the instruction that would have been executed if execution had not been stopped. The supervisor terminal indicates a halt. Leaves the values of CBIT, LINK, and the condition codes unchanged.

This instruction saves the contents of registers in a memory location specified by the RSAVPTR. The contents of RSAVPTR can be accessed by an LDLR/STLR instruction with address '40037. The registers are saved in their physical order. (See Chapter 9 of the System Architecture Reference Guide for the format of these register files.) The saved register file order is shown in Table 2-3.

| 6350,                                                                                                                                                                    | 2350 to 2755,                                                                                                                                                                                                                                  |                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 9750 to 9955 II                                                                                                                                                          | 9650 and 9655                                                                                                                                                                                                                                  | Earlier Systems* |
| User Reg Set 3<br>User Reg Set 4<br>User Reg Set 1<br>User Reg Set 2<br>Microcode Reg File,<br>Set 2<br>Indirect Reg Set<br>Microcode Reg File,<br>Set 1<br>DMx Reg File | User Reg Set 1<br>User Reg Set 2<br>User Reg Set 3<br>User Reg Set 3<br>User Reg Set 4<br>User Reg Set 5<br>User Reg Set 6<br>User Reg Set 7<br>User Reg Set 8<br>DMx Reg File<br>Microcode Reg File,<br>Set 1<br>Microcode Reg File,<br>Set 2 | User Reg Set 2   |

# Table 2-3 Order of Saved Registers after HLT

\* The earlier systems are listed in "About This Book". Of these, the 850 has two ISPs. For each ISP, the order of saved registers is identical to the order shown for the rest of the 50 Series.

Note

This is a restricted instruction.
IAB Interchange A and B 00000001000001 (S, R, V mode form)

Interchanges the contents of A and B. Leaves the values of LINK, CBIT, and the condition codes unchanged.

Interchange Bytes of A Register 1100001011100000 (S, R, V mode form)

Interchanges the bytes of A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ICL

Interchange Bytes and Clear Left 1100001001100000 (S, R, V mode form)

Interchanges the bytes of A, then clears the left byte to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ICR

Interchange Bytes and Clear Right 1 1 0 0 0 0 1 0 1 0 1 0 0 0 0 0 (S, R, V mode form)

Interchanges the bytes of A, then clears the right byte to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

► ILE

Interchange L and E 1100001100001100 (S, R, V mode form)

Interchanges the values of E and L. Leaves the values of CBIT, LINK, and the condition codes unchanged.

 IMA address Interchange Memory and A IX101111000Y00ER\2 (V mode long) DISPLACEMENT\16
 IX101111000000CE\2 (R mode long) [DISPLACEMENT\16]

IX1011DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Interchanges the contents of A and the contents of the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

The IMA instruction is nonatomic, and, especially for dual-stream processors, cannot be used for spin-locks. In these cases, use the STAC instruction instead.

INA function, device Input to A 1 0 1 1 0 0 FUNCTION\4 DEVICE\6 Valid for modes S, R

Loads data from the specified device into A. Leaves the values of CBIT, LINK, and the condition codes unchanged. See Chapter 11 of the System Architecture Reference Guide for more information.

Note

This is a restricted instruction.

INBC address Interrupt Notify Beginning, Clear Active Interrupt 0 0 0 0 0 0 1 0 1 0 0 0 1 1 1 1 (V mode form) AP\32

Notifies a semaphore at the specified address during phantom interrupt code. Restores the state of the interrupted process by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from microcode temporary registers PSWPB and PSWKEYS. Places the notified process at the beginning of the appropriate priority level queue. Issues a CAI pulse to clear the currently active interrupt, and enables interrupts. The values of CBIT, LINK, and the condition codes are indeterminate. A process exchange will occur if the notified process is of a higher priority than the interrupted process. See Chapter 9 of the System Architecture Reference Guide for more information.

## Note

INBC is a restricted instruction.

This instruction is normally used to transfer from phantom interrupt code to an interrupt process. See Chapter 10 of the System Architecture Reference Guide for more information.

INEN address
 Interrupt Notify Beginning
 0 0 0 0 0 0 1 0 1 0 0 0 1 1 0 1 (V mode form)
 AP\32

Notifies a semaphore at the specified address during phantom interrupt code. Restores the state of the interrupted process by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from microcode temporary registers PSWPB and PSWKEYS. Places the notified process at the beginning of the appropriate priority level queue, and enables interrupts. Does not issue a CAI pulse to clear the currently active interrupt. The values of CBIT, LINK, and the condition codes are indeterminate. A process exchange will occur if the notified process is of a higher priority than the interrupted process. See Chapter 9 of the System Architecture Reference Guide for more information.

#### Note

This is a restricted instruction.

This instruction is normally used to transfer from phantom interrupt code to an interrupt process. See Chapter 10 of the System Architecture Reference Guide for more information.

INEC address
 Interrupt Notify End, Clear Active Interrupt
 0 0 0 0 0 0 1 0 1 0 0 0 1 1 1 0 (V mode form)
 AP\32

Notifies a semaphore at the specified address during phantom interrupt code. Restores the state of the interrupted process by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from microcode temporary registers PSWPB and PSWKEYS. Places the notified process at the end of the appropriate priority level queue. Issues a CAI pulse to clear the currently active interrupt, and enables interrupts. The values of CBIT, LINK, and the condition codes are indeterminate. A process exchange will occur if the notified process is of a higher priority than the interrupted process. See Chapter 9 of the System Architecture Reference Guide for more information.

## Note

INEC is a restricted instruction.

This instruction is normally used to transfer from phantom interrupt code to an interrupt process. See Chapter 10 of the System Architecture Reference Guide for more information.

INEN address Interrupt Notify End 000001010001100 (V mode form) AP\32

Notifies a semaphore at the specified address during phantom interrupt code. Restores the state of the interrupted process by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from microcode temporary registers PSWPB and PSWKEYS. Places the notified process at the end of the appropriate priority level queue, and enables interrupts. Does not issue a CAI pulse to clear the currently active interrupt. The values of CBIT, LINK, and the condition codes are indeterminate. A process exchange will occur if the notified process is of a higher priority than the interrupted process. See Chapter 9 of the System Architecture Reference Guide for more information.

Note

This is a restricted instruction.

This instruction is normally used to transfer from phantom interrupt code to an interrupt process. See Chapter 10 of the System Architecture Reference Guide for more information.

► INH

Inhibit Interrupts 

Inhibits interrupts by setting bit 1 of the modals to 0. Inhibits interrupts until an enable interrupts instruction executes. The processor ignores any interrupt requests that are made over the I/OThis instruction takes effect immediately. Leaves the values of bus. CBIT, LINK, and the condition codes unchanged.

#### Note

#### This is a restricted instruction.

INHL

Inhibit Interrupts (Local)

000000100000001 (S, R, V mode form)

This 850 instruction performs the same actions as INH does. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

This is a restricted instruction.

INHM Inhibit Interrupts (Mutual) 00000010000000000 (S, R, V mode form)

For the 850, a processor checks the availability of the mutual exclusion lock. If available, the processor sets this lock and inhibits interrupts. Otherwise, it waits for the lock to be released by the other processor and then sets the lock and inhibits interrupts. Leaves the values of CBIT, LINK, and the condition codes unchanged.

Note

This is a restricted instruction.

INHP Inhibit Interrupts (Process) 0 0 0 0 0 1 0 0 0 0 0 0 1 0 (S, R, V mode form)

For the 850, a processor checks the availability of the process exchange lock. If available, the processor sets it and inhibits interrupts. Otherwise, it waits for the lock to be released by the other processor and then sets the lock and inhibits interrupts. Leaves the values of CBIT, LINK, and the condition codes unchanged.

Note

This is a restricted instruction.

Loads the contents of the S and R mode keys into A. Reads the low-order 8 bits of the floating exponent (address trap location 6) register along with the high-order 8 bits of the keys register. Leaves the values of CBIT, LINK, and the condition codes unchanged.

INT

Convert Floating Point to Integer 1100000101101100 (S, R mode form)

Converts the double precision floating-point number contained in the floating accumulator to a 31-bit integer and stores the result in A and bits 2 to 16 of B. Bit 1 of B (bit 17 of the result) is forced to 0. Ignores the fractional portion of the floating-point number. Overflow occurs if the value in the floating accumulator is less than  $-2^{**}30$  or greater than  $(2^{**}30)-1$ . If overflow occurs, a floating-point exception occurs. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

Convert Floating Point to Integer 1100000101011001 (V mode form)

Converts the double precision number contained in the floating accumulator to a 16-bit integer and stores the result in A. Ignores the fractional portion of the floating-point number. For example, -4.5 is converted to -4 and +4.5 is converted to +4. Overflow occurs if the value in the floating accumulator is less than  $-2^{**15}$  or greater than  $(2^{**15})-1$ . If overflow occurs, a floating-point exception occurs. If no floating-point exception occurs, CBIT is reset to 0.

At the end of this instruction, the B register contents are indeterminate. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

INTL Convert Floating Point to Long Integer 1100000101011011 (V mode form)

Converts the double precision floating-point number contained in the floating accumulator to a 32-bit integer and stores the result in L. Ignores the fractional portion of the floating-point number contained in the floating accumulator. For example, -4.5 is converted to -4 and +4.5 is converted to +4. Overflow occurs if the floating-point number is less than  $-2^{**}31$  or greater than  $(2^{**}31)-1$ . If overflow occurs, a floating-point exception occurs. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

 IRS address Increment and Replace Memory IX101011000Y00BR\2 (V mode long) DISPLACEMENT\16
 IX101011000000CB\2 (R mode long) [ DISPLACEMENT\16 ]

IX1010DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Fetches the contents of the location specified by EA, adds 1 (a 16-bit increment), and stores the result back in the location specified by EA. Skips the next location if the incremented value is O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

IRIC Interrupt Return, Clear Active Interrupt 0000000110000011 (V mode form)

Returns from an interrupt. Restores the state existing before the interrupt by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from the values saved in microcode temporary registers PSWPB and PSWKEYS. Issues a CAI pulse to clear the currently active interrupt, and enables interrupts.

#### Note

This is a restricted instruction.

# IRTN Interrupt Return 0 0 0 0 0 0 0 1 1 0 0 0 0 0 0 1 (V mode form)

Returns from an interrupt. Restores the state existing before the interrupt by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from the values saved in microcode temporary registers PSWPB and PSWKEYS, and enables interrupts. Does not issue a CAI pulse to clear the currently active interrupt.

#### Note

This is a restricted instruction.

IRX Increment and Replace X 110000001001100 (S, R, V mode form)

Increments the contents of X by 1 and stores the result in X. Skips the next 16-bit halfword if the incremented value is 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ITLB Invalidate STLB Entry 0000000110001101 (V mode form)

Invalidates the STLB entry that corresponds to the virtual address contained in L. The values of CBIT, LINK, and the condition codes are indeterminate. You must execute this instruction whenever you change the page table entry for the given address.

If you change an SDW or DTAR (explained in Chapter 4 of the <u>System</u> <u>Architecture Reference Guide</u>), you usually have to invalidate the entire STLB by issuing the instruction PTLB. A 0 in the segment number portion of L invalidates the IOTLB entry corresponding to the address specified by L.

Note

This is a restricted instruction.

JDX address Jump and Decrement X I 0 1 1 0 1 1 1 0 0 0 0 1 0 CB\2 (R mode long) [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Subtracts 1 from the contents of the index register, X. If the decremented value does not equal 0, the instruction loads EA into the program counter. If the decremented value is equal to 0, execution continues with the next sequential instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This instruction cannot do indexing. See Appendix B for more information.

► JIX address Increment X and Jump if Not Equal to 0 I 0 1 1 0 1 1 1 0 0 0 0 1 1 CB\2 (R mode form) [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Adds 1 to the contents of the index register, X. If the incremented value does not equal 0, the instruction loads EA into the program counter. If the incremented value is equal to 0, execution continues with the next sequential instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This instruction cannot do indexing.

JMP address Jump IX000111000Y00ER\2 (V mode long)

DISPLACEMENT\16

I X O O O I I I O O O O O CB (R mode long)[ DISPLACEMENT(16 ]

IX0001 DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Loads EA into the program counter. Leaves the values of CBIT, LINK, and the condition codes unchanged.

 JST address Jump and Store IX100011000Y00ER\2 (V mode long) DISPLACEMENT\16
 IX100011000000CE\2 (R mode long) [ DISPLACEMENT\16 ]

IXIOOODISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Stores the contents of the program counter in the location specified by EA. Execution continues at the location EA+1.

The JST instruction truncates the return address according to the addressing mode before storing it. The high-order bits of the memory location are not affected by the store. This allows you to preset the I or X bits in some modes as follows:

| Mode     | Allowed Presets |  |  |
|----------|-----------------|--|--|
| 16S      | I, X            |  |  |
| 32S, 32R | I               |  |  |
| 64R, 64V | none            |  |  |

#### Note

JST cannot be used in shared code. In Ring O, JST inhibits interrupts during execution of the next instruction.

This instruction may call only those subroutines residing in the same procedure segment as the instruction, because only the offset number field of the program counter is saved.

JSX address Jump and Save in X I 1 1 1 0 1 1 1 0 0 0 Y 1 1 ER\2 (V mode long) DISPLACEMENT\16

I 1 1 1 0 1 1 1 0 0 0 0 1 1 CB\2 (R mode long) [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Increments the contents of the program counter by 1 and loads the result into X. Loads EA into the program counter. For the 750 and 850, if the value of CB is 2 or 3, then the next 16 bits are skipped. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

JSX cannot do indexing. See Appendix B for more information.

This instruction may call only those subroutines residing in the same procedure segment as the instruction, because only the offset number field of the program counter is saved.

JSXB address Jump and Save in XB  $IX110011000Y10BR\2$  (V mode long) DISPLACEMENT\16 IX110011000010CB\2 (R mode long) [ DISPLACEMENT $\setminus 16$  ]

Calculates an effective address, EA. Loads the contents of the program counter into XB. Loads EA into the program counter. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

This instruction can make subroutine calls outside the current segment as well as within.

 JSY address Jump and Save in Y I X 1 1 0 0 1 1 0 0 0 Y 0 0 BR 2 (V mode long) DISPLACEMENT\16

IX1100DISPLACEMENT\16 (V mode short)

Calculates an effective address, EA. Loads Y with the location number of the program counter. Loads EA into the program counter. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

This instruction may call only those subroutines residing in the same procedure segment as the instruction, because only the offset number field of the program counter is saved.

# LCEQ

Load A on Condition Code EQ 1100001101000011 (V mode form)

If the condition codes reflect an equal to condition, the instruction loads A with a 1. If the condition codes reflect a not equal condition, the instruction loads A with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# ► LOGE

Load A on Condition Code GE 1100001101000100 (V mode form)

If the condition codes reflect a greater than or equal to condition, the instruction loads A with a 1. If the condition codes reflect a less than condition, the instruction loads A with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

LOGT

Load A on Condition Code GT 1100001101000101 (V mode form)

If the condition codes reflect a greater than condition, the instruction loads with a 1. If the condition codes reflect a less than or equal to condition, the instruction loads A with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

► LCLE

Load A on Condition Code LE 110000110100001 (V mode form)

If the condition codes reflect a less than or equal to condition, the instruction loads A with a 1. If the condition codes reflect a greater than condition, the instruction loads A with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# LCLT

Load A on Condition Code LT 1100001101000000 (V mode form)

If the condition codes reflect a less than condition, the instruction loads A with a 1. If the condition codes reflect a greater than or equal to condition, the instruction loads A with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# LCNE Load A on Condition Code NE 1100001101000010 (V mode form)

If the condition codes reflect a not equal condition, the instruction loads A with a 1. If the condition codes reflect an equal condition, the instruction loads A with a O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

 LDA address Load A

 I X 0 0 1 0 1 1 0 0 0 Y 0 0 ER\2
 (V mode long)
 DISPLACEMENT\16
 I X 0 0 1 0 1 1 0 0 0 0 0 0 CB\2
 (R mode long)
 [ DISPLACEMENT\16 ]

I X O O 1 O DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Loads the contents of the location specified by EA into A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

LDC flr Load Character 000000101100FLR010 (V mode form)

If the contents of the specified FIR are nonzero, the instruction fetches the single character pointed to by the appropriate FAR and loads it into bits 9 to 16 of A. When the FAR's bit field contains 0, it specifies the left byte (bits 1 to 8) of the 16-bit addressed quantity; when the bit field contains 8, the right byte (bits 9 to 16) is specified. This instruction loads zeros into bits 1 to 8 of A. Updates the contents of the appropriate FAR by 8 so that they point to the next character. Decrements the contents of the specified FIR by 1. Sets the condition codes to NE.

If the contents of the specified FLR are 0, the instruction sets the condition codes to EQ.

The instruction leaves the values of CBIT and LINK unchanged.

### Note

This instruction uses FARO when FLRO is specified, and FAR1 when FLRI is specified.

LDL address Load Long IX001011000Y11ER\2 (V mode form) DISPLACEMENT\16

Calculates a long (32-bit) effective address, EA. Loads the 32-bit contents of the location specified by EA into L. Leaves the values of CBIT, LINK, and the condition codes unchanged.

LDLR address Load L From Addressed Register I X 0 1 0 1 1 1 0 0 0 Y 0 1 BR\2 (V mode form) DISPLACEMENT\16

Calculates a 32-bit (1-word) effective address, EA. Loads L with the contents of the register file location specified by the offset portion of EA. Bit 2 and bit 12 of the offset portion of EA determine the actions of this instruction:

| Bit 2 | <u>Bit 12</u> | Action                                                                                                               |
|-------|---------------|----------------------------------------------------------------------------------------------------------------------|
| 1*    |               | Ignore bit 1 and bits 3 to 9. The offset portion of EA specifies an absolute register number from 0 to '377.         |
| 0*    | 1             | Bits 13 to 16 of the offset portion of EA<br>specify one of the registers '20 to '37 in the<br>current register set. |
| 0     | 0             | Bits 13 to 16 of the offset portion of EA specify one of the registers 0 to '17 in the current register set.         |
|       |               |                                                                                                                      |

\*This is a restricted instruction.

Leaves the values of CBIT and LINK unchanged; the values of the condition codes are indeterminate. See Chapter 9 of the <u>System</u> Architecture Reference Guide for more information on register sets.

LDX address Load X I 1 1 1 0 1 1 1 0 0 0 Y 0 0 BR\2 (V mode long) DISPLACEMENT\16 I 1 1 1 0 1 1 1 0 0 0 0 0 0 CB\2 (R mode long) [ DISPLACEMENT\16 ]

I 1 1 1 0 1 DISPLACEMENT\10 (S, R, V mode short form)

Calculates an effective address, EA. Loads X, the index register, with the contents of the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged. For 750 and 850 processors in R mode only, if CB contains 2 or 3, the first 16 bits of the next instruction will be skipped.

#### Note

LDX cannot specify indexing, though an address calculated in the indirect chain may do so in 16S mode. See Appendix B for more information.

LDY address Load Y I 1 1 1 0 1 1 1 0 0 0 Y 0 1 BR\2 (V mode form) DISPALCEMENT\16

Calculates an effective address, EA. Loads Y with the contents of the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

LDY cannot do indexing. See Appendix B for more information.

LEQ Load A on A Equal to 0 1100000100001011 (S, R, V mode form)

If the contents of A are equal to 0, the instruction loads A with a 1. If the contents of A are not equal to 0, the instruction loads A with a O. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.) LF Load False 110000100001110 (S, R, V mode form)

Loads A with a O. Leaves the values of LINK and CBIT unchanged. The values of the condition codes are indeterminate.

LFEQ Load A on F Equal to 0 1100001001001011 (V mode form)

If the contents of the floating accumulator are equal to 0, the instruction loads A with a 1. If the F contents are not equal to 0, the instruction loads A with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.) LFEQ works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the <u>System</u> Architecture Reference Guide.)

► LFGE

Load A on Floating Accumulator Greater Than or Equal to 0 1100001001001100 (V mode form)

If the contents of the floating accumulator are greater than or equal to 0, the instruction loads A with a 1. If the F contents are less than 0, the instruction loads A with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.) LFGE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

LFGT

Load A on Floating Accumulator Greater Than 0 1100001001001101 (V mode form)

If the contents of the floating accumulator are greater than 0, the instruction loads A with a 1. If the F contents are less than or equal to 0, the instruction loads A with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.) LFGT works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

LFLE Load A on Floating Accumulator Less Than or Equal to 0 1100001001001001 (V mode form)

If the contents of the floating accumulator are less than or equal to 0, the instruction loads A with a 1. If the F contents are greater than 0, the instruction loads A with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.) LFLE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

LFLI flr,data Load FLR Immediate 00000101100FLR011 (V mode form) INTEGER\16

Loads the 16-bit, unsigned integer contained in bits 17 to 32 (the second halfword) of the instruction into the specified FIR. Clears the upper bits of the FIR. Leaves the values of CBIT, LINK, the condition codes, and the associated FAR unchanged.

LFLT Load A on Floating Accumulator Less Than 0 1100001001001000 (V mode form)

If the contents of the floating accumulator are less than 0, the instruction loads A with a 1. If the F contents are greater than or equal to 0, the instruction loads A with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.) LFLT works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

LFNE Load A on Floating Accumulator Not Equal to 0 1100001001001010 (V mode form)

If the contents of the floating accumulator are not equal to 0, the instruction loads A with a 1. If the F contents are equal to 0, the instruction loads A with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.) LFNE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

IGE Load A on Greater Than or Equal to 0 1 1 0 0 0 0 1 0 0 0 0 1 1 0 0 (S, R, V mode form)

If the contents of A are greater than or equal to 0, the instruction loads A with a 1. If the contents of A are less than 0, the instruction loads A with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.) This instruction has the same opcode as LLGE.

IGT Load A on Greater Than 0 1100000100001101 (S, R, V mode form)

If the A contents are greater than 0, the instruction loads A with 1. If the A contents are less than or equal to 0, the instruction loads A with 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LIOT address Load IOTLB 0 0 0 0 0 0 0 0 0 1 0 0 1 0 0 (V mode form) AP\32

Loads a specified IOTLB entry. The following list shows the contents of the LIOT entry and the origin of the information.

# Origin Description

AP in LIOT Virtual address in I/O segment (calculated from EA).

- Page table Physical address (translation of virtual address) obtained from I/O segment. If the fault bit is set to 1, a page fault occurs.
- L register Target virtual address containing the segment number and page number to be used by procedures accessing this information. This is used to help invalidate the proper locations in the cache. The segment number and low-order 10 bits (offset number in the page) are ignored.

The values of CBIT, LINK, and the condition codes are indeterminate.

#### Note

LIOT is a restricted instruction.

# LIE

Load on A Less Than or Equal to 01 1 0 0 0 0 0 1 0 0 0 0 1 0 0 1 (S, R, V mode form)

If the contents of A are less than or equal to 0, the instruction loads A with 1. If the A contents are greater than 0, the instruction loads A with 0. Leaves the values of LINK and CBIT unchanged. The condition codes contain the result of the comparison. (See Appendix A.)

# 🕨 TTEÓ

Load A on L Equal to 0 1100001101001011 (V mode form)

If the contents of L are equal to 0, the instruction loads A with a 1. If the contents of L are not equal to 0, the instruction loads A with a O. Leaves the values of LINK and CBIT unchanged. The condition codes contain the result of the comparison. (See Appendix A.)

# LIGE

Load A on L Greater Than or Equal to 0 1100000100001100 (V mode form)

If the contents of L are greater than or equal to 0, the instruction loads A with a 1. If the contents of L are less than 0, the instruction loads A with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes contain the result of the comparison. (See Appendix A.) This instruction has the same op code as IGE.

# LLGT

Load A on L Greater Than 0 1100001101001101 (V mode form)

If the L contents are greater than 0, the instruction loads A with 1. If the L contents are less than or equal to 0, the instruction loads A with 0. Leaves the values of LINK and CBIT unchanged. The condition codes contain the result of the comparison. (See Appendix A.)

# LLL n Long Left Logical 0 1 0 0 0 0 1 0 0 0 N\6 (S, R, V mode form)

Shifts the contents of A and B to the left, bringing zeros into bit 16 of B. Shifts bits out of bit 1 of B into bit 16 of A. CBIT and LINK contain the value of last bit shifted out of A; the values of all other bits shifted out of A are lost. Leaves the values of the condition codes unchanged.

N contains the two's complement of the number of shifts to perform. If N contains 0, the instruction performs 64 shifts.

► LLLE

Load A on L Less Than or Equal to 0 1100001101001001 (V mode form)

If the contents of L are less than or equal to 0, the instruction loads A with 1. If the L contents are greater than 0, the instruction loads A with 0. Leaves the values of LINK and CBIT unchanged. The condition codes contain the result of the comparison. (See Appendix A.)

Load A on L Less Than 0 1100000100001000 (V mode form)

If the contents of L are less than 0, the instruction loads A with 1. If the L contents are greater than or equal to 0, the instruction loads A with 0. Leaves the values of LINK and CBIT unchanged. The condition codes contain the result of the comparison. (See Appendix A.) This instruction has the same operation as LLT.

LLNE Load A on L Not Equal to 0 1100001101001010 (V mode form)

If the contents of L are not equal to 0, the instruction loads A with a 1. If the contents of L are equal to 0, the instruction loads A with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes contain the result of the comparison. (See Appendix A.) LLR n Long Left Rotate 0 1 0 0 0 0 1 0 1 0 N\6 (S, R, V mode form)

Shifts the contents of A and B left, rotating bit 1 of A into bit 16 of B. Bit 1 of B shifts into bit 16 of A. CBIT and LINK contain a copy of the last bit rotated into bit 16 of B. Leaves the values of the condition codes unchanged.

N contains the two's complement of the number of shifts to perform. If N contains 0, the instruction performs 64 shifts.

LLS n Long Left Shift 0100001001N\6 (V mode form)

Shifts the 32-bit integer in L left arithmetically, bringing zeros into bit 32. Bits shifted out of bit 1 are lost. If bit 1 changes state, it is interpreted as an overflow and causes an integer exception. If no integer exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

LLS n Long Left Shift 0 1 0 0 0 0 1 0 0 1 N\6 (S, R mode form)

Shifts the 31-bit integer contained in A and B left arithmetically, bringing zeros into bit 16 of B. Bit 1 of B does not take part in the shift; bit 2 of B is shifted into bit 16 of A. Bits shifted out of bit 1 of A are lost. If bit 1 of A changes state, it is interpreted as an overflow and causes an integer exception. If no integer exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

LLT Load on A Less Than 0 110000010001000 (S, R, V mode form)

If the contents of A are less than 0, the instruction loads A with 1. If the A contents are greater than or equal to 0, the instruction loads A with 0. Leaves the values of LINK and CBIT unchanged. The condition codes contain the result of the comparison. (See Appendix A.) This instruction has the same operation as LLLT.

LNE Load on A Not Equal to 0 110000100001010 (S, R, V mode form)

If the contents of A are not equal to 0, the instruction loads A with a 1. If the contents of A are equal to 0, the instruction loads A with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes contain the result of the comparison. (See Appendix A.)

LPID Load Process ID 0 0 0 0 0 0 1 1 0 0 0 1 1 1 1 (V mode form)

Loads the process ID from bits 1 to 10 of A into RPID (the process ID register). This contains the 10 most significant bits of the user's address space. Leaves the values of CBIT, LINK, and the condition codes unchanged.

The RPID data is used to update the process ID field of an STLB entry as required. This RPID data is later used during subsequent memory accesses to verify that STLB data is still valid (STLB hit) or not (STLB miss). This register is for internal machine operation, and should not normally be modified by the user.

Note

This is a restricted instruction.

LPSW address
 Load PSW
 0 0 0 0 0 0 1 1 1 0 0 1 0 0 1 (V mode form)
 AP\32

Changes the status of the processor by loading new values into the program counter, keys, and modals. Inhibits interrupts for one instruction.

Addresses a 64-bit (4-halfword) block at the specified location. The block has the following.

| Offset in Block | Contents                |         |        |          |        |
|-----------------|-------------------------|---------|--------|----------|--------|
| 1 to 2          | New program<br>numbers) | counter | (ring, | segment, | offset |
| 3               | New keys                |         |        |          |        |
| 4               | New modals              |         |        |          |        |

LPSW loads the program counter and keys of the currently running process with the contents of the first three offsets (bits 1 to 48), then loads the processor modals with the contents of the fourth offset (bits 49 to 64).

The new value of bit 15 in the keys, the in-dispatch bit, can temporarily halt execution of the current process. This bit is altered by software only during a cold or warm start. If bit 15 is 0, the currently executing process will continue to execute, but at a location defined by the new value of the program counter. If bit 15 is 1, the processor enters the dispatcher and dispatches the ready process with the highest priority. When execution resumes for the process that was temporarily halted, note that execution resumes at the point defined by the value of the new program counter.

Regardless of the value of bit 15, the new value of the modals takes effect immediately, since the modals are associated with the processor, not the process.

This instruction loads the 64 bits (four halfwords) of the register set that the STLR instruction cannot correctly load. STLR does not update the separate hardware registers the processor uses to maintain duplicate information for optimization.

Never use this instruction to change bits 9 to 11 of the modals. These bits specify the current user register set. This means that if you do not know the current value of these bits, you must do the following each time you want to execute an LPSW.

- 1. Inhibit interrupts.
- 2. Read the current values of modal bits 9 to 11 (use LDLR).
- 3. Mask the old values of the modal bits into the new information.
- 4. Load the new information into the modals with an LPSW.

For the two common uses of LPSW, you do not have to perform this sequence, since the values of modal bits 9 to 11 are predictable. When you use LPSW after a Master Clear to turn on processor exchange mode,

bits 9 to 11 are 010 because the processor is always initialized to register set 2. When you use LPSW to return from a fault, check, or interrupt, simply reload the values stored by the break because these values are still correct.

Also note that you should not use LPSW to set bits 16 (the save done bit) or 15 (the in-dispatcher bit) of the keys, unless you are merely loading status following a fault, check, or interrupt. When issuing LPSW after a Master Clear, make sure you load zeros into both of these bits.

Note

LPSW is a restricted instruction. This instruction inhibits interrupts during execution of the next instruction.

IRL n Long Right Logical 0 1 0 0 0 0 0 0 0 N\6 (S, R, V mode form)

Shifts the contents of A and B right, bringing zeros into bit 1 of A. Shifts bit 16 of A into bit 1 of B. CBIT and LINK contain the value of the last bit shifted out of B; the values of all other bits shifted out of B are lost. Leaves the values of the condition codes unchanged.

N contains the two's complement of the number of shifts to perform. If N contains 0, the instruction performs 64 shifts.

🕨 lRR n

Long Right Rotate 0 1 0 0 0 0 0 0 1 0 N 6 (S, R, V mode form)

Shifts the contents of A and B right, rotating bit 16 of B into bit 1 of A. Shifts bit 16 of A into bit 1 of B. CBIT and LINK contain a copy of the last bit rotated from B to A. Leaves the values of the condition codes unchanged.

N contains the two's complement of the number of shifts to perform. If N contains 0, the instruction performs 64 shifts.

IRS n Long Right Shift 010000001N\6 (V mode form)

Shifts the 32-bit integer contained in L right arithmetically. Shifts copies of bit 1, the sign bit, into each of the vacated bits. CBIT and LINK contain the value of the last bit shifted out of L; the values of

all other bits shifted out are lost. Leaves the values of the condition codes unchanged.

N contains the two's complement of the number of shifts to perform. If N contains 0, the instruction performs 64 shifts.

IRS n Long Right Shift 0 1 0 0 0 0 0 0 1 N\6 (S, R mode form)

Shifts right arithmetically the 31-bit integer contained in A and B, leaving bit 1 of A unaffected. Bit 1 of B does not take part in the shift; bit 16 of A is shifted into bit 2 of B. Shifts copies of bit 1 of A into each of the vacated bits. CBIT and LINK contain the value of the last bit shifted out of B; the values of all other bits shifted out of B are lost. Leaves the values of the condition codes unchanged.

N contains the two's complement of the number of shifts to perform. If N contains O, the instruction performs 64 shifts.

LT Load True 11000001000011111 (S, R, V mode form)

Loads A with a 1. Leaves the values of LINK and CBIT unchanged. The values of the condition codes are indeterminate.

MPL address Multiply Long IX111011000Y11ER\2 (V mode form) DISPLACEMENT\16

Calculates an effective address, EA. Multiplies the 32-bit integer in L by the 32-bit integer in the location specified by EA. Stores the 64-bit result in L and E. The 150/250, 450/550/250-II, I450-II, and 2250 processors leave the CBIT and LINK unchanged. The other 50 Series processors reset the CBIT to 0 and leave the value of LINK indeterminate. For all 50 Series processors, the condition codes are unchanged. MPL cannot cause overflow or generate an integer exception.

MPY address Multiply IX111011000Y00ER\2 (V mode long) DISPLACEMENT\16

IX1110DISPLACEMENT\10 (V mode short)

Calculates an effective address, EA. Multiplies the 16-bit integer in A by the 16-bit integer in the location specified by EA. Stores the 32-bit result in A and B. Resets the CBIT to O. The value of LINK is indeterminate. Leaves the values of the condition codes unchanged.

## Note

This instruction cannot cause overflow.

MPY address Multiply IX111011000000CB\2 (R mode long) [DISPLACEMENT\16]

IXIIIODISPLACEMENT\10 (S mode; R mode short)

Calculates an effective address, EA. Multiplies the 16-bit integer in A by the 16-bit integer in the location specified by EA. Loads the 31-bit result in A and B. If the multiplier and multiplicand are both  $-(2^{**}15)$ , an integer exception occurs. If no integer exception occurs, CBIT is reset to 0. The value of LINK is indeterminate. For the 2350 to 9955 II, the condition codes are unchanged. For the earlier processors listed in "About This Book", the values of the condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

NFYB address Notify to Beginning 0000001010001001 (V mode form) AP\32

Notifies the semaphore at the address specified by the address pointer in the instruction. Uses LIFO (last in, first out) queueing. Does not clear the currently active interrupt. The values of CBIT, LINK, and the condition codes are indeterminate. See Chapter 9 of the <u>System</u> Architecture Reference Guide for more information.

## Note

This is a restricted instruction.

NFYE address Notify to End 0 0 0 0 0 1 0 1 0 0 0 1 0 0 0 (V mode form) AP\32

Notifies the semaphore at the address specified by the address pointer in the instruction. Uses FIFO (first in, first out) queueing. Does not clear the currently active interrupt. The values of CBIT, LINK, and the condition codes are indeterminate. See Chapter 9 of the <u>System</u> Architecture Reference Guide for more information.

#### Note

This is a restricted instruction.

Does nothing. Leaves the values of CBIT, LINK, and the condition codes unchanged.

OCP function, device Output Control Pulse 0 0 1 1 0 0 FUNCTION\4 DEVICE\6 (S, R mode form)

Sends a control pulse to perform the specified function to the specified device. This instruction never skips. Leaves the values of CBIT, LINK, and the condition codes unchanged. See Chapter 11 of the System Architecture Reference Guide for more information.

#### Note

This is a restricted instruction.

ORA address Inclusive OR IXO01111000Y10BR\2 (V mode form) DISPLACEMENT\16

Calculates an effective address, EA. Logically ORs the contents of the location specified by EA and the contents of A and stores the result in A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

OTA function, device Output From A 1 1 1 1 0 0 FUNCTION\4 DEVICE\6 (S, R mode form)

Transfers data from A to the specified device. Leaves the values of CBIT, LINK, and the condition codes unchanged. See Chapter 11 of the System Architecture Reference Guide for more information.

Note

This is a restricted instruction.

OTK Output Keys 0 0 0 0 0 0 1 0 0 0 0 1 0 1 (S, R mode form)

Stores the contents of A in the keys. Loads CBIT, LINK, and the condition codes as a result of the operation. Loads the low-order 8 bits of the floating exponent (address trap location 6) register with the low-order 8 bits of A. If this instruction is executed in Ring 0, it inhibits interrupt during execution of the next instruction.

PCL address Procedure Call IX100011000Y10ER\2 (V mode form) DISPLACEMENT\16

Sets CBIT, LINK, and the condition codes to the values contained in the ECB. See Chapter 8 of the System Architecture Reference Guide for a complete description of this instruction.

#### Note

When arguments are to be transferred to the called procedure, this instruction uses X and Y, destroying the previous contents of these registers. XB is updated if an AP has the S bit = 0. The contents of X, Y, and XB remain unchanged if no arguments are transferred. The contents of the condition codes, CBIT, and LINK are not correctly saved in the ECB along with the rest of the caller's keys.

PID Position for Integer Divide 000000001001001 (S, R mode form)

Moves the contents of bits 2 to 16 of A into bits 2 to 16 of B. Clears bit 1 of register B to 0 and extends the sign contained in bit 1 of A into bits 2 to 16 of A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### PIDA

Position for Integer Divide 0000000001001101 (V mode form)

Moves the contents of bits 1 to 16 of A into bits 17 to 32 of L. Extends the sign contained in bit 1 of A into bits 2 to 16 of A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

PIDL Position for Integer Divide Long 000000011000101 (V mode form)

Moves the contents of L into E and extends the sign contained in bit 1 of L into bits 2 to 32 of L. Leaves the values of CBIT, LINK, and the condition codes unchanged.

PIM Position After Multiply 000000001000101 (S, R mode form)

Moves bits 2 to 16 of B into bits 2 to 16 of A. This converts a 31-bit integer to a 16-bit integer. Leaves the values of CBIT, LINK, and the condition codes unchanged. Overflow does not cause an integer exception.

PIMA Position After Multiply 000000000001101 (V mode form)

Moves bits 17 to 32 of L into bits 1 to 16 of A. This converts a 32-bit integer to a 16-bit integer. An integer exception occurs if there is an overflow. (This occurs if bits 1 to 17 of L contain a value other than all zeros or all ones before the move.) If no integer exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

## Note

To position bits 17 to 32 of L in A, PIMA can modify all 32 bits of L. Since A and B overlap L, this swap means that the contents of B are indeterminate at the end of this instruction.

PIML Position After Integer Multiply Long 000000011000001 (V mode form)

Moves the contents of bits 1 to 32 of E into bits 1 to 32 of L. This converts a 64-bit integer to a 32-bit integer. An overflow causes an integer exception. If no integer exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

PRIN Procedure Return 0 0 0 0 0 0 1 1 0 0 0 1 0 0 1 (V mode form)

Deallocates the stack frame created for the executing procedure and returns to the environment of the procedure that called it.

To deallocate the frame, the instruction stores the current value of the stack base register into the free pointer. It then restores the caller's state by loading the caller's program counter, stack base register, linkage base register, and keys with the values contained in the frame being deallocated. Sets bits 15 to 16 of the keys to 0.

Loads the ring number in the program counter with the current ring number to allow outward returns but prevent inward returns.

PTLB Purge TLB

000000000110100 (V mode form)

L contains the address of a physical page, right justified. Based on the value of L bit 1, PILB purges either the first 128 locations or a single location. If L bit 1 contains a 1, the instruction performs a complete purge. If L bit 1 contains a 0, the instruction purges the page specified by L. Leaves the values of CBIT, LINK, and the condition codes indeterminate. See Chapters 1, 4, and 11 of the System Architecture Reference Guide for more information about the STLB and IOTLB.

Note

This is a restricted instruction.

On the 750, 850, and 2350 to 9955 II, insert a CRE (Clear E) instruction before PTLB. Since PTLB uses E as a pointer, the CRE zeros E before PTLB manipulates it. If an interrupt occurs during PTLB's execution, E points to the location PTLB is currently purging. PTLB leaves the contents of E in an undefined state at the end of its execution.

QFAD address Quad Precision Floating Add I X 0 1 0 1 1 1 0 0 0 Y 1 0 ER\2 (V mode long) DISPLACEMENT\16 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0

Calculates an effective address, EA. Adds the 112-bit, quad precision number contained in the locations specified by EA to the contents of QAC. (See Chapter 6 of the <u>System Architecture Reference Guide.</u>) Normalizes the result and loads it into QAC. An overflow or underflow causes a floating-point exception. If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Note

If QFAD is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFCM
 Quad Precision Floating Complement
 1 1 0 0 0 0 0 1 0 1 1 1 1 0 0 0 (V mode form)

Forms the two's complement of the value contained in QAC and normalizes it if necessary. (See Chapter 6 of the System Architecture Reference Guide.) Stores the result in QAC. An underflow or overflow causes a floating-point exception. If no floating-point exception occurs, resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

#### Note

If QFCM is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFCS address Quad Precision Floating Point Compare and Skip I X 0 1 0 1 1 1 0 0 0 Y 1 0 BR\2 (V mode long) DISPLACEMENT\16 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0

Calculates an effective address, EA. Compares the contents of QAC (see Chapter 6 of the <u>System Architecture Reference Guide</u>) to the 112-bit contents of the location specified by EA and skips as shown below.

| Condition          | Skip                         |
|--------------------|------------------------------|
| QAC > EA contents. | No skip.                     |
| QAC = EA contents. | Skip 16 bits (one halfword). |
| QAC < EA contents. | Skip 32 bits (two halfwords) |

The values of CBIT, LINK, and the condition codes are indeterminate. On some processors, QFCS works correctly only on normalized numbers as follows. The comparison has a maximum of three sequential stages: first the signs, then the exponents, and finally the fractions of the two numbers are compared for equality. If the comparison during any one of these stages reveals an inequality, the results are returned and the instruction ends. Unnormalized numbers are unexpected and produce unexpected results. Other processors actually perform a subtract, resulting in a proper comparison.

## Note

If QFCS is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFDV address Quad Precision Floating Point Divide I X 0 1 0 1 1 1 0 0 0 Y 1 0 BR\2 (V mode long) DISPLACEMENT\16 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1

Calculates an effective address, EA. Divides the contents of QAC by the 112-bit contents of the location specified by EA. Normalizes the result and stores the whole quotient into QAC. An overflow, underflow, or divide by 0 causes a floating-point exception. If there is no floating-point exception, resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide.

### Note

If QFDV is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFLD address
 Quad Precision Floating Point Load
 I X 0 1 0 1 1 1 0 0 0 Y 1 0 BR\2 (V mode long)
 DISPLACEMENT\16
 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Calculates an extended, augmented effective address, EA. Performs one of the following actions with the value contained in the location specified by EA. Loads bits 1 to 112 into QAC and zeros QAC bits 113 to 128, or loads 128 bits into QAC. In either case, no normalization occurs. (See Chapter 6 of the <u>System Architecture Reference Guide</u> for more information.) Leaves the values of CBIT, LINK, and the condition codes unchanged.

Note

If QFLD is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFLX address

Quad Precision Floating Point Load Index I 0 1 1 0 1 1 1 0 0 0 Y 1 1 ER\2 (V mode long) DISPLACEMENT\16

Calculates an effective address, EA. Shifts the 16-bit contents of the location specified by EA to the left three times to multiply the contents by eight. Shifts in zeros on the right and shifts data out on the left first through bit 2 and then bit 1. Leaves the values of CBIT, LINK, and and the condition codes unchanged.

#### Note

QFLX cannot do indexing. See Appendix B for more information.

If QFLX is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.) QFMP address
 Quad Precision Floating Point Multiply
 I X 0 1 0 1 1 1 0 0 0 Y 1 0 BR\2 (V mode long)
 DISPLACEMENT\16
 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0

Calculates an effective address, EA. Multiplies the contents of QAC by the 112-bit contents of the location specified by EA. (See Chapter 6 of the <u>System Architecture Reference Guide.</u>) Normalizes the result if necessary and stores it into QAC. An overflow or underflow causes a floating-point exception. If there is no floating-point exception, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

#### Note

If QFMP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFSB address Quad Precision Floating Point Subtract I X 0 1 0 1 1 1 0 0 0 Y 1 0 BR\2 (V mode long) DISPLACEMENT\16 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1

Calculates an effective address, EA. Subtracts the contents of the locations specified by EA from the 112-bit contents of QAC. (See Chapter 6 of the System Architecture Reference Guide.) Normalizes the result if necessary and loads it into QAC. An overflow or underflow causes a floating-point exception. If there is no floating-point exception, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

# Note

If QFSB is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFST address
 Quad Precision Floating Point Store
 I X 0 1 0 1 1 1 0 0 0 Y 1 0 BR\2 (V mode long)
 DISPLACEMENT\16
 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1

Calculates an effective address, EA. Stores the 128-bit contents of QAC into the 128 bits of memory specified by EA. (See Chapter 6 of the System Architecture Reference Guide.) Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

This instruction does not normalize the result before storing it into the specified memory location.

If QFST is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

Quad to Integer, in Quad Convert 1100000101111010 (V mode form)

Strips the fractional portion of QAC as described in Table 2-4.
| Tal  | le  | 2-  | 4  |
|------|-----|-----|----|
| QINQ | Act | :ic | ns |

| Exponent Value    | Action I                                                                                                                                                                                                                                               |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| '337 <= Exp       | No operation.                                                                                                                                                                                                                                          |
| '200 < Exp < '337 | <pre>If sign &gt;= 0, strip fractional part of QAC for result. If sign &lt; 0 and fractional part &lt;&gt; 0, strip fractional part of QAC and increment integer portion of QAC by 1. If sign &lt; 0 and fractional part = 0, no action is done.</pre> |
| '200 = Exp        | <pre>If sign &gt;= 0, result = 0. If sign &lt; 0 and bits 2 to 96 = 0, result = -1. If sign &lt; 0 and bits 2 to 96 &lt;&gt; 0, result = 0.</pre>                                                                                                      |
| ' '200 > Exp      | Result = 0.                                                                                                                                                                                                                                            |

The QINQ instruction can cause a floating-point exception; an exception does not alter the contents of QAC. If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Note

If QINQ is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QIQR

Quad to Integer, in Quad Convert Rounded 1100000101111011 (V mode form)

Strips the fractional portion of QAC as described in Table 2-5.

Table 2-5 QIQR Actions

| Exponent Value                 | Action                                                                                                                                                                                                                                              |                     |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| ' 337 <= Exp                   | No operation.                                                                                                                                                                                                                                       | 1                   |
| ' '177' < Exp < '337<br>'<br>' | If sign >= 0, round.*<br>  If sign < 0 and fractional part <> 0.5,**<br>  round and strip the fractional part<br>  of QAC.                                                                                                                          | <br> <br> <br> <br> |
| Exp = '177                     | <pre>If sign &gt;= 0, result = 0. If sign &lt; 0 and bits 2 to 96 = 0, result = -1. If sign &lt; 0 and bits 2 to 96 &lt;&gt; 0, result = 0. For all cases increment integer part by 1 if I it exists and the most significant bit of QAC = 1.</pre> |                     |
| Exp < '177                     | The result is 0.                                                                                                                                                                                                                                    | I                   |

- \* Rounding occurs if the MSB of the QAC fraction is 1. For example, add the MSB of the QAC fraction to itself and carry out to the QAC integer.
- \*\* 0.5 implies a QAC fraction with the MSB = 1 and all other bits = 0.

The QIQR instruction can cause a floating-point exception; an exception does not alter the contents of QAC. If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

Note

If QIQR is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

RBQ address Remove Entry From Bottom of Queue 1100001111001101 (V mode form) AP\32

The address pointer in this instruction points to the QCB for a queue. The instruction removes the entry from the bottom of the referenced queue and loads it into A. If the queue is not empty, sets the condition codes to NE; if empty, resets A to O and sets the condition codes to EQ. Leaves the values of CBIT and LINK unchanged.

. 🕨 RCB

RUB Reset CBIT to 0 110000001000000 (S, R, V mode form)

Resets CBIT to 0. Leaves the values of LINK and the condition codes unchanged.

# RMC

Reset Machine Check Flag to 0 0000000000010001 (S, R, V mode form)

Resets the MCM flag (bits 15 to 16 of the modals) to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged. Inhibits interrupts during execution of the next instruction.

## Note

This is a restricted instruction.

RRST address Restore Registers 0 0 0 0 0 0 0 1 1 1 0 0 1 1 1 1 (V mode form) AP\32

Calculates an effective address, EA, from the 32-bit address pointer in the instruction. This specifies the starting address of a save area for the general, floating, and XB registers. The save area format is shown in Table 2-6. Restores the contents of the general, floating, and XB registers from this save area. Bits 1 to 16 of the save area are a save mask, whose format appears in Figure 2-4. A mask bit value of 1 means that the corresponding register had nonzero contents that have been saved in the save area; a mask bit value of 0 means that the corresponding register's contents were 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

Table 2-6 RRST Save Area Format

| 1                                                                                                                                                                                                |                                                                                                                                                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1         1       2 to 5         6 to 9         10 to 11         12 to 13         14 to 15         15 to 17         18 to 19         20 to 21         22 to 23         24 to 25         26 to 27 | Save mask                 FR1 (F)                 FR0                 K, GR7                 GR6                 Y, S, GR5                 GR4                 E, GR3                 A, B, L, GR2                 GR1                 GR0 |

| 1     | 4  | 5   | 6 ' | 78  | 9   |   | 10  | 11  | 12  | 13     | 14  | 15 | 16 |
|-------|----|-----|-----|-----|-----|---|-----|-----|-----|--------|-----|----|----|
| 1 000 | 00 | FR. | LI  | FRO | I X | 1 | - 1 | Y I | - 1 | E   L, | B,A |    |    |

## Save Mask Format, RRST and RSAV Instructions Figure 2-4

RSAV address

Save Registers 0000000111001101 (V mode form) AP\32

Calculates an effective address, EA, from the 32-bit address pointer in the instruction. This specifies the starting address of a save area for the general, floating, and XB registers. The save area format is shown in Table 2-7. Bits 1 to 16 of the save area are a save mask, whose format appears in Figure 2-5. This instruction sets the mask bit of each register as follows: to 1 if the register's contents have a nonzero value; to 0 if a 0 value. Saves the nonzero contents of the general, floating, and XB registers in the save area. Leaves the values of CBIT, LINK, and the condition codes unchanged.

| RSAV Sav | 'e Area f'ormat |
|----------|-----------------|
| Offset # | Contents        |
| 1        | Save mask       |
| 2 to 5   | FR1 (F)         |
| 6 to 9   | I FRO           |
| 10 to 11 | IX, GR7         |
| 12 to 13 | I GR6           |
| 14 to 15 | IY, S, GR5      |
| 15 to 17 | GR4             |
| 18 to 19 | E, GR3          |
| 20 to 21 | A, B, L, GR2    |
| 22 to 23 | GR1             |
| 24 to 25 | I GRO           |
| 26 to 27 | I XB            |

|      | Tabl | le 2-7 | 7      |
|------|------|--------|--------|
| RSAV | Save | Area   | Format |

| 1   | 4   | 5   | 6 | 78  | 3 | 9 | נ | 10 |   | 11 |  | 12 | 3 | 13 | 5 | 14    | 1 | 5 | 16 | 5 |
|-----|-----|-----|---|-----|---|---|---|----|---|----|--|----|---|----|---|-------|---|---|----|---|
| 000 | 0 1 | FR] | L | FRO | ! | X | 1 | _  | 1 | Y  |  |    |   | E  |   | L,B,A |   |   |    |   |

## Save Mask Format, RRST and RSAV Instructions Figure 2-5

# RTQ address

Remove Entry From Top of Queue 1100001111001100 (V mode form) AP\32

The address pointer in this instruction is to the QCB for a queue. The instruction removes the entry from the top of the referenced queue, and loads it into A. If the queue is empty, the instruction resets A to 0 and the condition codes to EQ; if not empty, sets the condition codes to NE. Leaves the values of CBIT and LINK unchanged.

RTS
 Reset Time Slice
 0 0 0 0 0 0 1 0 1 0 0 1 0 0 1 (V mode form)
 Valid for the 550-II, 750, 850, I450, and new processors.

The A register contains a negative value representing the number of milliseconds in the new time slice. The time slice is determined by counting ITH up every 1.024 milliseconds until zero, when the time

slice ends. Therefore, ITH is the two's complement of the number of milliseconds remaining in the time slice. The elapsed timer contains the total number of 1.024 millisecond units that have elapsed since process creation plus the full count of the current time slice. Combining ITH and ET by addition gives the total elapsed time.

RTS adds the current value of the interval timer (locations 16 to 17 of the PCB) to the contents of the elapsed timer (locations 10 to 11 of the PCB), then subtracts the contents of A from the sum of the timers. Stores the result in the elapsed timer. Loads the contents of A into the interval timer. Leaves the contents of A unchanged. The values of CBIT, LINK, and the condition codes are unchanged.

The addition performed by this instruction is equivalent to the following series of instructions.

| LDA  | ITH           | /* load A with the contents of ITH                      |
|------|---------------|---------------------------------------------------------|
| SUB  | RV            | /* subtract reset value (in RV) from contents of A      |
| PIDA |               | /* sign extend the contents of A into L bits 17 to 32   |
| SRC  |               | /* skip next 16-bit halfword if CBIT is 0 (no overflow) |
| CMA  |               | /* complement A                                         |
| ADL  | $\mathbf{ET}$ | /* add contents of L and contents of ET                 |
| STL  | $\mathbf{ET}$ | /* store contents of L in ET                            |
| LDA  | RV            | /* load A with reset value                              |
| STA  | ITH           | /* store the reset value into ITH                       |
|      |               |                                                         |

Note

RTS is a restricted instruction.

# SIA Subtract 1 From A 1 1 0 0 0 0 0 0 1 0 0 1 0 0 0 (S, R, V mode form)

Subtracts 1 from the contents of A and stores the result in A. If the number to be decremented is  $-(2^{**}15)$ , an integer exception occurs, and the instruction loads  $(2^{**}15)-1$  into A. If no overflow occurs, the instruction resets CBIT to O. LINK contains the borrow bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

🕨 S2A

Subtract 2 From A 110000011001000 (S, R, V mode form)

Subtracts 2 from the contents of A and stores the result in A. If the number to be decremented is  $-(2^{**15})-1$  or  $-2^{**15}$ , an integer exception occurs and the instruction loads  $(2^{**15})-1$  or  $(2^{**15})-2$ , respectively, into A. If no overflow occurs, the instruction resets CBIT to O. LINK contains the borrow bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

SAR n Skip on A Register Bit Reset to 0 10000001011N\4 (S, R, V mode form)

Skips the next 16-bit halfword if bit n in register A contains O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

N specifies the bit to test. A value of 0 indicates bit 1; 1, bit 2; and so on.

#### Note

The assembler converts n to the octal equivalent of bit number minus 1.

# SAS n Skip on A Register Bit Set to 1 100000101011N\4 (S, R, V mode form)

Skips the next 16-bit halfword if bit n in register A contains 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

N specifies the bit to test. A value of 0 indicates bit 1, and so on.

#### Note

The assembler converts n to the octal equivalent of bit number minus 1.

SBL address
 Subtract Long
 I X 0 1 1 1 1 1 0 0 0 Y 1 1 BR\2 (V mode form)
 DISPLACEMENT\16

Calculates an effective address, EA. Subtracts the 32-bit integer in the location specified by EA from the contents of L. Stores the results in L. If the result is greater than  $(2^{**}31)-1$ , an integer exception occurs and the instruction loads bit 1 of L with a 1 and bits 2 to 32 with (result -  $(2^{**}31)$ ).

If the result is less than  $-(2^{*}31)$ , an integer exception occurs and the instruction loads bit 1 of L with a 0 and bits 2 to 32 with the negative of (result +  $(2^{*}31)$ ).

If no overflow occurs, the instruction resets CBIT to 0. The instruction loads LINK with the borrow bit. The condition codes reflect the outcome of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.



Set CBIT to 1

1100000110000000 (S, R, V mode form)

Sets the value of CBIT to 1. The value of LINK is indeterminate. Leaves the values of the condition codes unchanged. Enters single precision mode by resetting bit 2 of the keys to 0. Subsequent LDA, STA, ADD, and SUB instructions manipulate 16-bit integers. Leaves the values of CBIT, LINK, and the condition codes unchanged.

SGT

Skip on A Greater Than 0 100000010010000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the contents of A are greater than 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

SKP n

Skip

Skips the next sequential 16-bit halfword if the specified condition is met. Leaves the values of CBIT, LINK, and the condition codes unchanged.

This instruction allows you to test for several conditions. The table below shows the conditions available to test and information about the associated instruction.

Table 2-8 SKP Conditions

| 1 | Mnem                                                 |   | Opcode   Condition                                                                                                                                                                                                                                                                                                           |
|---|------------------------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | NOP<br>SKP<br>SLT<br>SGE<br>SLN<br>SLZ<br>SNE<br>SEQ |   | 101000 + No operation.100000 + Unconditional skip.101400 + Skip on bit 1 of A equal to 1.100400 + Skip on bit 1 of A equal to 0.101100 + Skip on bit 16 of A equal to 1.100100 + Skip on bit 16 of A equal to 1.100100 + Skip on bit 16 of A equal to 0.101040 + Skip on A not equal to 0.100040 + Skip on A not equal to 0. |
| 1 | SS1*                                                 | I | 101020   Skip on sense switch 1 set to 1.                                                                                                                                                                                                                                                                                    |
| I | SR1*                                                 | I | 100020   Skip on sense switch 1 reset to 0.                                                                                                                                                                                                                                                                                  |
| I | SS2*                                                 | I | 101010   Skip on sense switch 2 set to 1.                                                                                                                                                                                                                                                                                    |
| I | SR2*                                                 | I | 100010   Skip on sense switch 2 reset to 0.                                                                                                                                                                                                                                                                                  |
| I | SS3*                                                 | I | 101004   Skip on sense switch 3 set to 1.                                                                                                                                                                                                                                                                                    |
| Ι | SR3*                                                 | ł | 100004   Skip on sense switch 3 reset to 0.                                                                                                                                                                                                                                                                                  |
| I | SS4*                                                 | ł | 101002   Skip on sense switch 4 set to 1.                                                                                                                                                                                                                                                                                    |
| I | SR4*                                                 | 1 | 100002   Skip on sense switch 4 reset to 0.                                                                                                                                                                                                                                                                                  |
| I | SSS*                                                 | T | 101036   Skip on any sense switches set to 1.                                                                                                                                                                                                                                                                                |
| I | SSR*                                                 | I | 100036 + Skip on all sense switches reset to 0.1                                                                                                                                                                                                                                                                             |
| 1 | SSC                                                  | 1 | 101001   Skip on CBIT set to 1.                                                                                                                                                                                                                                                                                              |
| I | SRC                                                  | I | 100001   Skip on CBIT reset to 0.                                                                                                                                                                                                                                                                                            |

#### Note

#### \*These are restricted instructions.

You do not have to specify the unique mnemonic to test a particular condition; you can specify the SKP mnemonic and give the correct bit configuration for bits 7 to 16 of the desired test. Make sure that you set bit 7 of the SKP instruction properly: if it contains a 1, the skip occurs if any of the specified conditions are true; if it contains a 0, the skip occurs if all of the specified conditions are false.

SKS function, device Skip on Condition Satisfied 0 1 1 1 0 0 FUNCTION 4 DEVICE 6 (S, R mode form)

Tests for the condition specified in the function field of the instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. See Chapter 11 of the System Architecture Reference Guide for more information.

## Note

SKS is a restricted instruction.

# SLE Skip if A Less Than or Equal to 0 1000001010010000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the contents of A are less than or equal to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# SLN

Skip on LSB of A Nonzero 100000100100000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if bit 16 of A is 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## SIZ

Skip on LSB of A Zero 10000000100000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the bit 16 in A equals 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## SMCR

Skip on Machine Check Reset to 0 10000001000000 (S, R, V mode form)

Skips the next 16-bit halfword if the machine check flag is 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

If the processor is operating in machine check mode, this instruction has no meaning; it executes as an unconditional skip.

# SMCS Skip on Machine Check Set to 1 1000001010000000 (S, R, V mode form)

Skips the next 16-bit halfword if the machine check flag is 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

If the processer is operating in machine check mode, this instruction has no meaning; it executes as a NOP.

SMI

Skip on A Minus 1000001100000000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the contents of A are less than 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

SNZ

Skip on A Nonzero 10000100010000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the contents of A are not equal to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

> SPL

Skip on A Plus 1000000100000000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the contents of A are greater than or equal to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

SRC

Skip on CBIT Reset to 0 1000000000000001 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the value of CBIT is 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

SSC Skip on CBIT Set to 1 1000001000000001 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the value of CBIT is 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

SSM Sot th

Set the Sign of A Minus 1100000101000000 (S, R, V mode form)

Sets bit 1 of A to 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

SSP

Set the Sign of A Plus 11000000100000 (S, R, V mode form)

Sets bit 1 of A to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

SSSN
 Store System Serial Number
 010000011001000 (V mode form)

This instruction is applicable only for the 2350 to the 9955 II. A 14-character system identifier programmed into the processor during manufacturing consists of a 2-character plant location code followed by a 12-digit number. (These characters and numbers are in 7-bit ASCII format.) SSSN writes this system identifier into a 16-halfword block at the address specified by the XB register. (A halfword is 16 bits.) The first 8 halfwords of this block hold the system serial number string as provided by manufacturing; the remaining halfwords are reserved for future expansion and are 0.

Leaves the values of CBIT, LINK, and the condition codes indeterminate.

Note

If SSSN is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

 STA address Store A Into Memory I X 0 1 0 0 1 1 0 0 0 Y 0 0 BR\2 (V mode long) DISPLACEMENT\16
 I X 0 1 0 0 1 1 0 0 0 0 0 0 CB\2 (R mode long) [ DISPLACEMENT\16 ]

I X 0 1 0 0 DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Stores the contents of the A register in the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

STAC address Store A Conditionally 0 0 0 0 0 1 0 1 0 0 0 0 0 0 0 (V mode form) AP\32

Compares the contents of B with the contents of the location referenced by the specified address pointer. If the two values are equal, the instruction stores the contents of A into that referenced location. If the two values are not equal, execution continues with the next instruction. Leaves the values of CBIT and LINK unchanged. Sets the condition codes to EQ if the store occurs and to NE if not.

The comparison and store will not be separated by execution of other instructions. This means that no instruction can alter the contents of the specified memory location between the compare and the store.

Note

This instruction is useful when two cooperating, sequential processes are manipulating shared data. It is interlocked against direct memory I/O; this means you can use it to interlock a process with a DMA, DMC, or DMQ channel, as well as to interlock a memory location that is possibly accessed by I/O.

SIC flr Store Character 000000101101FLR010 (V mode form)

If the contents of the specified FIR are nonzero, the instruction stores the contents of bits 9 to 16 of A into the character byte pointed to by the appropriate FAR. Updates the contents of the appropriate FAR so that they point to the next character. Decrements the contents of the specified FIR by 1. Sets the condition code NE. If the contents of the specified FLR are 0, the STC instruction sets the condition code EQ and does not store a character.

The STC instruction leaves the values of LINK and CBIT unchanged.

#### Note

When the instruction specifies FLRO, FARO is used; FLR1, FAR1.

STEX Stack Extend 000001011001101 (V mode form)

Extends the length of the procedure stack.

A and B contain a 32-bit number specifying the halfword size of the extension. (A halfword is 16 bits.)

The firmware rounds up the number specified by A and B to an even number of halfwords. The instruction uses this value to allocate a block of memory to the procedure stack. The extension and the initial stack do not have to be contiguous, since there may not have been enough room left in the initial stack to contain a complete frame.

The instruction returns a segment number/offset number in A and B that specifies the starting address of the extension.

The extension is automatically deallocated when the current procedure completes execution. There is no limit on the number of extensions you can make.

A stack fault occurs if there is no room for the extension. The values of CBIT, LINK, and the condition codes are indeterminate. See Chapters 8 and 10 of the <u>System Architecture Reference Guide</u> for more information about this instruction, stacks, and stack faults.

STFA far, address Store FAR 00000101101FAR000 (V mode form) AP\32

Stores the specified FAR contents as a hardware recognizable indirect pointer at the memory location referenced by the specified address pointer. If the bit number field of that FAR contains 0, the instruction stores the first 32 bits (2 halfwords) of the pointer and clears the pointer's extend bit to 0. If the bit number field of that FAR does not contain 0, the instruction saves all 48 bits (three halfwords) of the pointer and sets the pointer's extend bit to 1. Leaves the values of CBIT, LINK, and the condition codes indeterminate. STL address Store Long IX010011000Y11ER\2 (V mode form) DISPLACEMENT\16

Calculates an effective address, EA. Stores the contents of L in the 32-bit location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

STLC address Store L Conditionally 0 0 0 0 0 1 0 1 0 0 0 0 1 0 0 (V mode form) AP\32

Calculates an effective address, EA. Stores the contents of L into the 32-bit location specified by EA if and only if the contents of the specified location equal the contents of E. Leaves the values of CBIT and LINK unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

## Note

This instruction is useful when two cooperating, sequential processes are manipulating shared data. It is interlocked against direct memory I/O; this means you can use it to interlock a process with a DMA, DMC, or DMQ channel, as well as to interlock a memory location that is possibly accessed by I/O.

STLR address Store L Into Add

Store L Into Addressed Register IX001111000Y01ER\2 (V mode form) DISPLACEMENT\16

Calculates a 32-bit (1-word) effective address, EA. Stores the contents of L into the register location specified by the offset portion of EA. Bit 2 and bit 12 of the offset portion of EA determine the actions of this instruction as follows.

Bit 2 Bit 12 Ignore bit 1 and bits 3 to 9. The offset 1\* portion of EA specified an absolute register number from 0 to '377. 0\* 1 Bits 13 to 16 of the offset portion of EA specify one of the registers '20 to '37 in the current register set.

Action

0 0 Bits 13 to 16 of the offset portion of EA specify one of the registers 0 to '17 in the current register set.

\*This is a restricted instruction.

STLR leaves the values of CBIT and LINK unchanged; the values of the condition codes are indeterminate. See Chapter 9 of the System Architecture Reference Guide for more information about register sets.

#### Note

Do not use the STIR instruction to write into the keys or modals. You can use LPSW or a mode control operation to change either of these registers. Under no circumstances should you try to change the value of the current register set bits contained in the modals.

In addition, do not change the contents of the procedure base register (PB) with this instruction. Use either LPSW or a control transfer. Loading any value other than 0 into PBL will change future effective address calculations for the currently running process.

► STPM Store Processor Model Number 0000000000010100 (V mode form)

Stores the CPU model number and microcode revision number in an 8-halfword field. (A halfword is 16 bits.) XB contains a pointer to the field. The format of the field is shown in Table 2-9.

| Halfword | Name                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 to 2   | Processor<br>Model<br>Number | Contains a code specifying the machine:         OL - 400/500, no       15L - 9950         Rev B microcode       16L - 9650         1L - 400, Rev. B       17L - 2550         microcode       18L - 9955         2L - Reserved       19L - 9750         3L - 350       21L - 2350         4L - 450/550       22L - 2655         5L - 750       23L - 9655         6L - 650       25L - 2450         7L - 250       30L - 9955 II         8L - 850       31L - 2755         9L - 250-II       34L - 6350         10L - 550-II       42L - 9755         11L - 2250       30L - 9755 |
| 3 to 4   | Microcode<br>Revision        | Offset 3:         Bits 1 to 8       Reserved         Bits 9 to 16       Manufacturing microcode         revision number         Offset 4:         Bits 1 to 16       Engineering microcode         revision number                                                                                                                                                                                                                                                                                                                                                               |
| 5        | Processor<br>Line            | Specifies options enabled for this machine:<br>Bits 1 to 15 Reserved; must be 0<br>Bit 16 Marketing segment<br>specification bit                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6        | Extended<br>Microcode<br>ID  | To be implemented.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7 to 8   |                              | Reserved for future use.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Table 2-9 STPM Memory Field Format

This instruction leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

STPM is a restricted instruction.

ł

STIM Store Process Timer 0 0 0 0 0 0 0 1 0 1 0 0 1 0 0 0 (V mode form)

Valid for the 550-II, 850, I450, and 2350 to 9955 II.

The current process time is represented by the sum of the 32-bit elapsed time (stored in the PCB) and the 32-bit interval timer (contained in the CPU hardware). Bit 17 of the elapsed time is equivalent in weight to bit 1 of the interval time. This operation is equivalent to the following sequence of instructions.

| LDLR | PB% + '25 | /* | Get PCB address.              |
|------|-----------|----|-------------------------------|
| ADL  | = '10L    | /* | Offset of elapsed time.       |
| STL  | TEMP1     | /* | Elapsed time address -> Temp. |
| LDLR | PB% + '30 | /* | Read timer.                   |
| IAB  |           | /* | Store low order               |
| STA  | XB% + 2   | /* | 16 bits.                      |
| IAB  |           | /* | Adjust                        |
| PIDA |           | /* | weighting.                    |
| ADL  | TEMP1,*   | /* | Add elapsed time.             |
| STL  | XB% + 0   |    | -                             |

Leaves the values of the CBIT, LINK, and condition codes indeterminate. This instruction is not implemented on the 2250.

STX address Store X I 0 1 1 0 1 1 1 0 0 0 Y 0 0 ER\2 (V mode long) DISPLACEMENT\16

I 0 1 1 0 1 1 1 0 0 0 0 0 0 CB\2 (R mode long) [ DISPLACEMENT\16 ]

I 0 1 1 0 1 DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Stores the contents of X at the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

STX cannot directly specify indexing, though an address in the indirection chain may do so in 16S mode. See Appendix B for more information.

STY Store Y I 1 1 1 0 1 1 1 0 0 0 Y 1 0 BR\2 (V mode form) DISPLACEMENT\16

Calculates an effective address, EA. Stores the contents of Y at the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

The STY instruction cannot do indexing. See Appendix B for more information.

SUB address Subtract IX011111000Y00ER\2 (V mode long) DISPLACEMENT\16

I X 0 1 1 1 1 1 0 0 0 0 0 0 CB\2 (R mode long) [ DISPLACEMENT\16 ]

IXO111DISPLACEMENT\10 (S mode; R, V mode short)

Calculates an effective address, EA. Fetches the 16-bit integer contained in the location specified by EA and subtracts them from the contents of A. Stores the results in A.

If the result is greater than or equal to  $2^{**15}$ , an integer exception occurs and the instruction sets CBIT to 1 and loads bit 1 of A with a 1 and bits 2 to 16 with (result minus  $(2^{**15})$ ).

If the result is less than  $-2^{**15}$ , an integer exception occurs and the instruction loads bit 1 of A with 0 and bits 2 to 16 with the negative of (result +  $(2^{**15})$ ).

If no overflow occurs, the instruction resets CBIT to 0. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

SVC Supervisor Call 000000101000101 (S, R, V mode form)

Supervisor call. Generates a directed fault. Leaves the values of CBIT, LINK, and the condition codes unchanged.

This instruction allows you to make an operating system request that is addressing mode independent. By software convention, this instruction sends an operation code and pointers to the operating system to generate a fault. For more information, refer to Chapter 10 of the System Architecture Reference Guide.

► SZE

Skip on A Zero 100000000100000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the contents of A equal O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

🕨 TAB

Transfer A to B 1100000011001100 (V mode form)

Transfers the contents of A into B. Leaves the values of CBIT, LINK, and the condition codes unchanged.

TAK

Transfer A to Keys 0000001000001101 (V mode form)

Moves a copy of the contents of A into the keys. Loads CBIT, LINK, and the condition codes as a result of the operation. Resets bits 15 to 16 of the keys to 0.

#### Note

If the new contents of the keys specifies a new addressing mode, the new mode takes effect with the instruction immediately following TAK.



Transfer A to X 1100000101000100 (V mode form)

Loads X with a copy of the contents of A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

TAY

Transfer A to Y 1100000101000101 (V mode form)

Loads Y with a copy of the contents of A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

TBA

Transfer B to A 1100000110000100 (V mode form)

Transfers a copy of the contents of B to A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

TCA Two's Complement A 1100000100000111 (S, R, V mode form)

Forms the two's complement of the contents of A and stores the result in A. If the number to be complemented is  $-2^{**15}$ , an integer exception occurs and the instruction loads  $-2^{**15}$  into A. If no integer exception occurs, the instruction resets CBIT to O. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

TCL Two's Complement Long 1100001010001000 (V mode form)

Forms the two's complement of the contents of L and stores the result in L. If the number to be complemented is  $-2^{*31}$ , an integer exception occurs and the instruction loads  $-2^{*31}$  into L. If no integer exception occurs, the instruction resets CBIT to O. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

TFLL flr Transfer FLR to L 000000101101FLR011 (V mode form)

Transfers the contents of the specified FIR into L as an unsigned, 32-bit integer. Clears bits 1 to 11 of L to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

TKA Transfer Keys to A 00000100000101 (V mode form)

Moves a copy of the keys into A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# TLFL flr Transfer L to FLR 000000101101FLR001 (V mode form)

Transfers the 32-bit unsigned integer contained in L into the specified FIR. Clears bits 1 to 11 of L to 0 so that bits 1 to 6 of the specified FIR will be 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This instruction allows you to load the specified FIR with a value computed at execution time. The maximum allowable integer you can load is 2\*\*20. This number is 21 bits wide and equals the number of bits in a 64K segment.

TSTQ address Test Queue 1100001111101111 (V mode form) AP\32

The address pointer in this instruction is to the QCB of a queue. This instruction tests the referenced queue and sets A to equal the number of items in the queue. Sets the condition codes to EQ when the queue is empty. If the queue is not empty, sets the condition codes to NE. Leaves the values of CBIT and LINK unchanged.

🕨 TXA

Transfer X to A 1100001000011100 (V mode form)

Transfers a copy of the contents of X to A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

TYA Transfer Y to A 1100001001010100 (V mode form)

Transfers a copy of the contents of Y to A. Leaves the values of CBIT, LINK, and the condition codes unchanged.

WAIT address
 Wait
 0 0 0 0 0 0 0 1 1 0 0 1 1 0 1 (V mode form)
 AP\32

The address pointer in this instruction is to a 16-bit semaphore counter, C. The instruction increments C. If C is greater than 0, either the resource is not available, or the event has not occurred. The instruction removes the PCB from the ready list, suspending the process, and adds it to the wait list associated with the semaphore. It then makes the register set available, turns off the process timer, and goes to the dispatcher to find another process to run. The dispatcher enables interrupts.

If C is less than or equal to 0, the currently executing process continues.

If the instruction places the PCB on the wait list, no general registers are saved. This means that a process cannot depend on these registers to be intact after this instruction occurs. This instruction potentially clears the general, floating, and XB registers.

Leaves CBIT, LINK, and the condition codes unchanged.

For more information about semaphores, the dispatcher, PCBs, and wait lists, refer to Chapter 9 of the System Architecture Reference Guide.

Note

This is a restricted instruction.

# XAD Decimal Add 00000100100000 (V mode form)

Performs a decimal arithmetic operation under control of FARO, FAR1, and L.

FARO contains the address of field 1. FARI contains the address of field 2. L contains the control word; fields B and C of the control word specify the decimal operation to be performed, as shown in Table 2-10.

## Table 2-10 XAD Decimal Operations

|       | В |   | С |   | Operation | 1 | Destination |  |
|-------|---|---|---|---|-----------|---|-------------|--|
| '<br> | 0 | I | 0 | T | +F1+F2    | I | F2          |  |
| I     | 0 | Ι | 1 | i | +F1-F2    | Т | F2          |  |
| L     | 1 | T | 0 | ł | -F1+F2    | Ι | F2          |  |
| I     | 1 | 1 | 1 | ł | -F1-F2    | 1 | F2          |  |
|       |   |   |   |   |           |   |             |  |

The scale differential field in the control word specifies the difference in the decimal point alignment between Fl and F2:

- SD Relation of F1 and F2
- SD>0 F1 > F2
- SD=0 F1 = F2
- SD<0 F1 < F2

If the T bit contains a 1, the results will be forced positive. For more information about decimal arithmetic, refer to Chapter 6 of the System Architecture Reference Guide.

If the add operation results in an overflow, a decimal exception occurs. If no overflow occurs, the instruction sets CBIT to 0 to indicate success.

If a decimal exception occurs and bit 11 of the keys contains a 0, the instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

The registers used are GRO, GR1, GR3 (E), GR4, GR6, FARO, FAR1, FLRO, and FLR1. At the end of the XAD instruction, the contents of these registers is indeterminate. The value of LINK is indeterminate. The condition codes reflect the state of F2 after the decimal operation. (See Appendix A.)

> XBID

Binary to Decimal Conversion 0000001001100101 (V mode form)

Converts a binary number to a decimal number. FARO contains the decimal field address. L contains the control word.

This instruction uses fields A, E, and H in the control word. H specifies the length of the binary number and its location:

- H Length Location
- 0 16 bits EH register
- 1 32 bits E register
- 2 64 bits DAC register

Converts the specified binary integer to a decimal integer and stores the result in the location specified by FARO. Overflow results in a decimal exception. If no overflow occurs, the instruction resets CBIT to 0. Leaves the value of LINK indeterminate. The values of the condition codes are indeterminate.

The registers used are GRO, GR1, GR3 (E), GR4, GR6, FARO, and FIRO. At the end of the instruction, the contents of these registers are indeterminate.

When the source register contains a null string, the destination register will contain all zeros.

If a decimal exception occurs and bit 11 of the keys contains a 0, the instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Note

This instruction does not use or modify FAR1, FLR1, or FAC1.

XCA Exchange and Clear A 110000001000100 (S, R, V mode form)

Interchanges the contents of registers A and B, then clears A to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

XCB Exchange and Clear B 11000001000100 (S, R, V mode form)

Interchanges the values of A and B and then clears B to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

XCM Decimal Compare 00000100100010 (V mode form)

Compares two decimal numbers and sets the condition codes depending on the result of the compare.

FARO contains the address of field 1 (F1). FAR1 contains the address of field 2 (F2). L contains the control word. This instruction uses fields A, B, C, E, F, G, and H of the control word.

Compares the two specified numbers. The instruction uses the G field of the control field to adjust the two numbers before the compare:

G

## Decision

- >0 Low-order digits of F1 only affect the initial borrow from the low-order digit of F2.
- <0 Assume F1 is zero-extended with low zeros.</p>

The registers used are GRO, GR1, GR3 (E), GR4, GR6, FIRO, and FIR1. At the end of this instruction, the contents of these registers are indeterminate. The CBIT is reset to 0 when there is no decimal exception. (This instruction cannot cause a decimal exception.) Leaves the value of LINK indeterminate. The condition codes reflect the result of the compare, as follows. OC Test Result

 $GT \qquad F2 > F1$ 

EQ F2 = F1

LT F2 < F1

XDTB Decimal to Binary Conversion 0000001001100110 (V mode form)

Converts a decimal string to a binary string.

FARO contains the address of the decimal string. L contains the control word; this instruction uses the A, E, and H fields. Field H specifies the length of the binary string and its location:

- H Length Destination Register
- 00 16 bits A register
- 01 32 bits L register
- 10 64 bits LIE

Converts the decimal string to a binary string of the specified type and stores it in the specified register. A conversion error causes a decimal exception. Leaves the value of LINK unchanged. The values of the condition codes are indeterminate.

The registers used are GRO, GR1, GR3 (E), GR4, GR6, FARO, and FLRO. At the end of this instruction the contents of these registers are indeterminate.

If a decimal exception occurs and bit 11 of the keys contains a 0, the instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Note

This instruction does not use or modify FAR1, FIR1, or FAC1.

XDV Decimal Divide 00000100100111 (V mode form)

Divides a decimal number, D2, by another, D1, and stores the quotient and remainder in the location of D2.

FARO contains the address of D1. FAR1 contains the address of D2. L contains the control word; this instruction uses fields A, B, C, E, F, H, and T.

Both decimal numbers must be in trailing sign embedded format. In addition, D2 must contain a number of leading zeros equal to the length of D1.

The instruction divides the two numbers. After the divide, the location of D2 contains the quotient of length (D2 length - D1 length) followed by the remainder of length (D1 length). Since D2 had leading zeros, no overflow can occur.

If the T bit contains a 1, the results will be forced positive. For more information about decimal arithmetic, refer to Chapter 6 of the System Architecture Reference Guide.

The registers used are GRO, GR1, GR3 (E), GR4, GR6, FARO, FAR1, FLRO, and FLR1. At the end of this instruction, the contents of these registers are indeterminate.

If D1 is 0, overflow occurs which causes a decimal exception. Decimal exceptions also occur if D1 or D2 have the incorrect data type or if the length of D2 is less than that of D1. If no overflow occurs, CBIT is reset to 0. At the end of the instruction, LINK and the condition codes contain undefined results.

If a decimal exception occurs and bit 11 of the keys contains a 0, the instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

XEC address
 Execute
 I X 0 0 0 1 1 1 0 0 0 Y 1 0 ER\2 (V mode long)
 DISPLACEMENT\16
 I X 0 0 0 1 1 1 0 0 0 0 1 0 CE\2 (R mode long)
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Executes the instruction found at EA, but does not transfer control to that location. Leaves the values of CBIT, LINK, and the condition codes modified as specified by the executed instruction.

The XEC instruction has limited application since all instructions cannot be executed in this way. The XEC instruction is useful for 16-bit register generic instructions such as shifts, rotates, clears, interchanges, and NOPS.

The following instruction types should not be used with XEC since they may not execute properly or will produce undefined results: instructions that change the address mode, program counter, or instruction stream; instructions that cause arithmetic faults; decimal or character instructions; and generic skips.

XED Numeric Edit 000001001001010 (V mode form)

Edits the contents of a string under control of a subprogram.

The registers used are L, XB, FARO, FAR1, and FLRO. At the end of the instruction, the contents of these registers and the CBIT, LINK, and condition codes are indeterminate.

FARO contains the address of the source string. The source string must be leading separate sign type and must have at least the same number of decimal digits and the decimal point alignment as called for in the edit subprogram.

FAR1 contains the address of the destination string. Bits 1 to 8 of A contain the floating character; bits 9 to 16, the status register. Bits 1 to 8 of B contain the number of remaining bytes to be processed (used if a fault or interrupt occurs). Bits 9 to 16 of B contain the suppression character whose initial value is determined by bit 12 of the keys ('240 if bit 1 contains 0; '40 if bit 12 contains 1). XB contains the address of the edit subprogram.

The instruction uses an edit subprogram to alter a source string and store the edit result in a destination location(s). To set up, perform a decimal move to correct the type, alignment, and length of the number to be edited. Next, use a LCEQ instruction to set up the initial contents of the register.

Each 16-bit halfword in the edit subprogram has the format shown in Figure 2-6.

|   | 1 | 2 | 3 | 4 |   | 89 |   | 16 |
|---|---|---|---|---|---|----|---|----|
| 1 | L | 0 | ) |   | E |    | M |    |

| Edit | Subprogram | Halfword | Format |
|------|------------|----------|--------|
|      | Figure     | e 2-6    |        |

M is a suboperator modifier.

The XED instruction uses several variables internally to control the edit subprogram. These are shown in Table 2-11.

## Table 2-11 XED Internal Variables

|                |      |                                                                                                                                                               | _              |
|----------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 1              | Var  | Definition                                                                                                                                                    | -<br> <br>     |
| <br> <br> <br> | SC   | Zero suppression character; contained in B. Initial<br>value is the space character ('240 or '40, depending<br>on whether bit 12 of the keys contains 0 or 1. | <br> <br> <br> |
| <br> <br>      | FC   | Floating edit character; contained in A. Initial<br>value is not defined.                                                                                     | <br> <br>      |
| <br> <br>      | SIGN | Sign of the source field. The first character fetch<br>sets up the value of this variable.                                                                    | <br> <br>      |
| 1              | SIG  | End zero suppression flag.                                                                                                                                    | I              |

There are 17 edit suboperators, shown in Table 2-12.

# Table 2-12 XED Suboperators

| I Subop                                                       | Mnem                                      | Name and Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00<br> <br> | ZS<br> <br> <br> <br> <br> <br> <br> <br> | Zero Suppress. Fetches M digits from the source field consecutively, each time checking SIG. If<br>SIG is 1, copies the digit into the destination string. If SIG is 0 and the digit is not 0, and the floating character (if defined) and copies the digit into the destination field.<br>If SIG is 0, the digit is not 0, and the string character is not defined, sets the SIG and copies the digit into the destination.<br>If SIG and the digit are both 0, substitutes SC for the 0 digit in the destination field. |
| 1 01                                                          |                                           | Insert Literal. Copies M into the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1 02                                                          | I SS                                      | Set Suppress Character. Sets SC to M and I increments XB by 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 03<br> <br>                                                   | <b>ICS</b><br> <br>                       | Insert Character. If SIG is 1, copies M into the<br>destination string. If SIG is 0, copies SC into<br>the destination string. Increments XB and FAR1<br>by 1.                                                                                                                                                                                                                                                                                                                                                            |
| 04<br>04<br>1<br>1<br>1<br>1<br>1<br>1<br>1                   | ID<br>I<br>I<br>I<br>I<br>I<br>I<br>I     | Insert Digits. If SIG is 0, and FC is defined,<br>copies FC and M digits into the destination field<br>then sets SIG to 1. Increments XB by 1, FARO by 1<br>M, and FAR1 by M+1. If SIG is 0 and FC is not<br>defined, sets SIG to 1 and copies M digits from<br>the source to the destination; increments XB by 1<br>1 and both FARO and FAR1 by M. If SIG is 1,<br>copies M digits from the source to the<br>destination and increments XB by 1 and both FARO 1<br>and FAR1 by M.                                        |
| 05<br> <br>                                                   | ICM<br> <br> <br>                         | Insert Character if Minus. If SIGN = 1, copies       I         M into the destination string. If SIGN = 1,       I         copies SC into the destination string.       I         Increments both SB and FAR1 by 1.       I                                                                                                                                                                                                                                                                                               |
| 06<br> <br>                                                   | ICP<br> <br>                              | Insert Character if Plus. If SIGN = 0, copies M         into the destination string. If SIGN = 1,         copies SC into the destination string.         Increments both SB and FAR1 by 1.                                                                                                                                                                                                                                                                                                                                |
| 07                                                            | SFC                                       | Set Floating Character. Sets FC to M and I increments XB by 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10                                                            | SFP                                       | Set Floating if Plus. If SIGN = 0, sets FC to M. I<br>If SIGN = 1, sets FC to SC. Increments XB by 1.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| i 11                                                          | SFM                                       | Set Floating if Minus. If SIGN = 1, sets FC to M.  <br>  If SIGN = 0, sets FC to SC. Increments XB by 1.                                                                                                                                                                                                                                                                                                                                                                                                                  |

Table 2-12 XED Suboperators (continued)

**^** 

| Subop                             | Mnem I                     | Name and Description                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12  <br> <br>                     | ISFS                       | Set Floating to SIGN. If SIGN = 0, sets FC to<br>'253. If SIGN = 1, sets FC to '255. Increments  <br>XB by ]                                                                                                                                                                                                                                                    |
| i 13<br>I                         | , <b>JZ</b>                | Jump if Zero. If the condition flag in A = 0,  <br>increments XB by 1. If the condition flag in A  <br>= 1, adds M to XB and then increments XB by 1.                                                                                                                                                                                                           |
| <b>14</b>                         | FS I                       | Fill with Suppression Characters. Copies SC  <br>M times into the destination string. Increments  <br>XB by 1 and FAR1 by M.                                                                                                                                                                                                                                    |
| 15  <br>   <br>                   |                            | Set Significance. If SIG = 0 and FC <> 0, inserts  <br>FC into the destination string, sets SIG to 1,  <br>and increments XB and FAR1 by 1. If SIG = 0 and  <br>FC = 0, sets SIG to 1 and increments XB and FAR1  <br>by 1. If SIG = 1, increments XB by 1.                                                                                                     |
| 16                                | IS I                       | Insert Sign. If SIGN = 0, copies '253 into the<br>destination string. If SIGN = 1, copies '255  <br>into the destination string. Increments XB by 1.                                                                                                                                                                                                            |
| <b>17</b>  <br>     <br>     <br> | SD  <br>     <br>     <br> | Suppress Digits. Fetches M digits from the source  <br>string and checks if they are '260. If the source  <br>digit = '260, inserts SC into the destination  <br>string. If the source digit <> '260, copies the  <br>source digit into the destination string.  <br>Increments XB by 1 and both FARO and FAR1 by M.                                            |
| 20  <br>   <br>   <br>     <br>   |                            | Embed Sign. Fetches M digits from the source  <br>string. If SIGN = 0, copies each digit into the  <br>destination string. If SIGN = 1, embeds a minus  <br>sign into each digit before copying it into the  <br>destination string. Table 6-15 shows the  <br>characters used to represent the sign/digit  <br>combinations. A } symbol represents negative 0. |

XMP Decimal Multiply 0000001001000 (V mode form)

Multiplies one decimal number, M, by another, Dl, and stores the result in D2's location in memory. M is right justified in field D2 at the start of the operation.

FARO contains the address of D1. FAR1 contains the address of D2. L contains the control word; this instruction uses fields A, B, C, E, F, G, H, and T. Field G, the scale differential, must contain the number of decimal digits in M.

The number of decimal digits in D2 is greater than or equal to the number of decimal digits in D1 <u>plus</u> the number of decimal digits in M (specified by G). Normally, the digits to the left (more significant side) of M are zeros. If this is not the case, then a partial product field is added in.

The instruction multiplies M by Dl and stores the result in the location specified by FAR1. The result of the multiply is:

Dl x M + partial product field

The partial product field is equal to:

length(D2) - M.

The partial product field is left justified in D2's location. The maximum partial product added in per traverse of the multiplicand is:

source digits + multiplier digits processed

There is also an implied weighting of the partial product field. The weighting is:

10 \*\* multiplier digits

If the T bit is set to 1, the results are forced positive. See Chapter 6 of the <u>System Architecture Reference Guide</u> for more information about decimal arithmetic.

A decimal exception occurs if there are more potential or actual product digits than there is space in D2.

The registers used are GRO, GR1, GR3 (E), GR4, GR6, FARO, FAR1, and XB. At the end of this instruction, the contents of these registers are indeterminate. Overflow causes a decimal exception; if no overflow occurs, resets CBIT to 0. LINK contains undefined results. At the end of the instruction, the condition codes reflect the state of the result. (See Appendix A.)

If a decimal exception occurs and bit 11 of the keys contains a 0, the XMP instruction sets CBIT to 1. If bit 11 contains a 1, the

instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

XMV Decimal Move 000000100100001 (V mode form)

Moves a string of characters from one location to another.

FARO contains the address of the source string. FARI contains the address of the destination string. L contains the control word; this instruction uses fields A, B, D, E, F, G, H and T.

The instruction moves the contents of the source field into the destination field from right to left. If the B field in the control word is 1, changes the the sign of the source field during the move. If the D field in the control word is 1 and the scale differential is greater than 0, the instruction rounds the source field during the move. If the scale differential (from the H field) is less than 0, the instruction pads the source field with SD trailing zeros before transferring.

Since the T bit is used by all systems for this instruction, the result is forced positive if this bit is set to 1.

The registers used are GRO, GR1, GR2 (L), GR3 (E), GR4, GR6, FARO, FAR1, FIRO, and FIR1. At the end of this instruction, the contents of these registers are indeterminate.

A decimal exception occurs if there are more non-zero source digits than there is room in the destination, after any padding. If there is no decimal exception, CBIT is reset to 0. Leaves the value of LINK indeterminate. The values of the condition codes reflect the state of the destination field after the move. (See Appendix A.)

If a decimal exception occurs and bit 11 of the keys contains a 0, the instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. If no exception occurs, the instruction sets CBIT to 0. See Chapter 10 of the System Architecture Reference Guide for more information about decimal exceptions.

#### Note

The source and destination strings may not overlap in memory.
ZCM Compare Character Field 0000001001001111 (V mode form)

Compares two fields and sets the condition codes depending on the result of the compare.

FARO contains the address of field 1 (F1). FIRO contains an integer specifying the length of F1. FAR1 contains the address of field 2 (F2). FIR1 contains an integer specifying the length of F2.

The instruction compares the contents of Fl and F2 on a byte by byte basis. If the fields are not of equal length, the instruction automatically extends the shorter string with space characters. A space character is '240 or '40 when bit 12 of the keys contains 0 or 1, respectively. Sets the condition codes as a result of the compare:

| Result of Compare | Set Condition Codes |
|-------------------|---------------------|
| F1 > F2           | GT                  |
| Fl = F2           | EQ                  |
| F1 < F2           | LT                  |

The registers used are GR3 (E), GR4, FARO, FAR1, FLRO, and FLR1; at the end of this instruction, the contents of these registers are indeterminate.

When the instruction completes execution, the values of CBIT and LINK are indeterminate.

#### Note

This instruction uses GR3, GR4, the FARs, and the FIRs during its operation. Since ZCM does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time.

ZED
 Character Field Edit
 0 0 0 0 0 1 0 0 1 0 0 1 0 0 1 (V mode form)

Controls an edit subprogram.

Uses the registers FARO, FAR1, FLRO, and XB. At the end of this instruction the contents of these registers are indeterminate. Leaves the values of CBIT, LINK, and the condition codes indeterminate.

FARO contains the address of the source string. FLRO specifies the length of the source string. FAR1 contains the address of the destination string. XB contains the address of the edit subprogram.

The instruction uses the edit subprogram to alter the source string, then loads the edited result into the destination string. The subprogram, addressed by the contents of XB, contains a list of commands, each with the format shown in Figure 2-7:





Bits 2 to 6 must be 0.

M, the operator modifier, specifies information E uses when editing the source string. (See Table 2-13.)

E, the edit suboperator, specifies the operation to be performed on the source string. Available values for E are shown in Table 2-13.

# Table 3-16 ZED Suboperators

| I Subop I                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Value | Action                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       | Copies characters from the source string into the<br>destination string. If the length of the source<br>string is greater than the contents of the M field,<br>then CPC moves a total of M source characters into<br>the destination string, increments FARO and FAR1 by<br>by M, increments XB by 1, and decrements FIRO by M.<br>If the length of the source string is less than the<br>the contents of the M field, then CPC moves the<br>rest of the source string into the destination<br>string, and then pads the remaining space to be<br>filled with spaces. (See note.) Increments FARO<br>by FIRO and FAR1 by M, increments XB by 1, and<br>and decrements FIRO by FIRO (so FIRO = 0). |
| INL  <br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 01    | Inserts M into the destination string and increments both XB and FAR1 by 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| I         SKC         I           I         I         I           I         I         I           I         I         I           I         I         I           I         I         I           I         I         I           I         I         I           I         I         I           I         I         I           I         I         I           I         I         I           I         I         I           I         I         I           I         I         I |       | Skips characters in the source string. If the<br>remaining length of the source string is greater<br>than or equal to the contents of the M field, then<br>SKC skips over the next M characters of the source<br>field by incrementing FARO by M and decrementing<br>FIRO by M. If the remaining length of the source<br>string is less than the contents of the M field,<br>SKC skips over FIRO characters in the source string<br>by incrementing FARO by FIRO and decrementing FIRO<br>by FIRO (FIRO = 0). In either case, SKC increments<br>XB by 1.                                                                                                                                          |
| BLK  <br>   <br>!                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 11    | Inserts M spaces (see note) into the destination<br>string, increments FAR1 by M, and increments XB<br>by 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

# Note

A space is '240 or '40, depending on whether bit 12 of the keys is 0 or 1. This instruction uses GR3, GR4, the FARs, and the FIRs during its operation. Since ZED does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time.

# ZFIL Fill Field With Character 0000001001001110 (V mode form)

Stores a character into a series of destination bytes.

Bits 9 to 16 of L contain the character to be stored. FAR1 contains the starting address of the destination field (byte aligned). FLR1 contains an integer specifying the length of the destination field (in bytes).

The instruction stores the character specified in L in each byte of the destination field. If FIR1 contains 0, no operation takes place. Leaves the values of CBIT, LINK, and the condition codes indeterminate.

The registers used are GR3 (E), GR4, FARO, FAR1, FLRO, and FLR1; at the end of this instruction, the contents of these registers are indeterminate.

Note

This instruction uses GR3, GR4, the FARs, and the FLRs during its operation. Since ZFIL does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time.

🕨 ZMV

Move Character Field 0000001001001100 (V mode form)

Moves a character field from one location to another.

FARO contains the address of the source string (byte aligned). FLRO specifies the length in bytes, N, of the source string. FAR1 contains the address of the destination string (byte aligned). FLR1 specifies the length in bytes, M, of the destination string.

Compares N and M. If N is less than M, the instruction moves the contents of the source string into the destination string followed by M-N space characters. (A space character is '240 or '40 when bit 12 of the keys is 0 or 1, respectively.) If the destination string is shorter, the instruction moves the first M characters of the source string into the destination string.

When the instruction completes, the values of FARO, FAR1, FIRO, FIR1, CBIT, LINK, and the condition codes are indeterminate.

#### Note

The ZMV instruction uses GR3, GR4, the FARs, and the FIRs during its operation. Since ZMV does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time. This instruction does not work with overlapping strings. See Chapter 6 of the <u>System Architecture</u> Reference Guide for more information.

# ZMVD

Move Characters Between Equal Length Strings 0000001001001101 (V mode form)

Moves characters from one string to another of equal length.

FARO contains the address of the source string. FARI contains the address of the destination string. FIRI contains the number of characters to move, N.

The instruction moves N characters from the source string to the destination string. Characters are moved from lower addresses to higher addresses.

The registers used are GR3 (E), GR4, FARO, FAR1, FLRO, and FLR1; at the end of this instruction, the contents of these registers are indeterminate. The values of CBIT, LINK, and the condition codes are indeterminate.

#### Note

The ZMV instruction uses GR3, GR4, the FARs, and the FIRs during its operation. Since ZMVD does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time. This instruction does not work with overlapping strings. See Chapter 6 of the <u>System Architecture</u> Reference Guide for more information. ZTRN Character String Translate 0000001001001000 (V mode form)

Translates a string of characters and stores the translations in the specified destination.

FARO contains the address of the source string (byte aligned). FARI contains the address of the destination string (byte aligned). FIRI specifies the length of the source and destination strings. XB contains the starting address of a translation table. Each byte in the 256-byte table contains an alphabetic character.

The ZTRN instruction uses the address in FARO to reference a character. It interprets this character as an integer, adding it to the contents of XB to form an address into the translation table. The instruction takes the referenced character in the translation table and writes it into the location specified by FAR1. After storing the character, the instruction increments the contents of FARO and FAR1 by 1, decrements the contents of FIR1 by 1, and repeats the operation until FIR1 contains 0.

At the end of the instruction, FARO and FAR1 point to the location that follows the last byte of the source and destination strings, respectively. FIR1 contains O. Leaves the values of XB, CBIT, LINK, and the condition codes unchanged.

#### Note

This instruction uses GR3, GR4, the FARs, and the FIRs during its operation. Since ZTRN does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time.

# 3 I Mode

# INTRODUCTION

This chapter contains descriptions for all 50 Series instructions used in I mode. In the description of each instruction, you will find:

- The instruction mnemonic followed by any arguments.
- The name of the instruction.
- The bit format of the instruction.
- Detailed information describing the instruction's action.
- Information about the how the instruction affects LINK, CBIT, and the condition codes.

#### Notation Conventions

Several abbreviations and symbols are used throughout this dictionary. Table 3-1 defines the dictionary notation.

# Table 3-1 Dictionary Notation

| Symbol         | Meaning                                                                                                                                                                                                                                   |  |  |  |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| <b>A</b>       | The 16-bit A register.                                                                                                                                                                                                                    |  |  |  |  |
| ADDRESS        | Encompasses all the elements needed to specify an<br>effective address. This term is used because various<br>addressing types require you to specify the elements<br>in different orders (such as indirect or pre- and<br>post-indexing). |  |  |  |  |
|                | Address pointer.                                                                                                                                                                                                                          |  |  |  |  |
| B<br>I         | The 16-bit B register.                                                                                                                                                                                                                    |  |  |  |  |
| BR             | Base register.                                                                                                                                                                                                                            |  |  |  |  |
|                | Bit 1 of the keys.                                                                                                                                                                                                                        |  |  |  |  |
|                | The double precision floating-point accumulator with 48 bits of mantissa and 16 bits of exponent.                                                                                                                                         |  |  |  |  |
| Displace-      | The number of halfwords to be added to the base register to form the effective address.                                                                                                                                                   |  |  |  |  |
| IDR            | Destination register (normal register specifier).                                                                                                                                                                                         |  |  |  |  |
| I E            | The 32-bit E register.                                                                                                                                                                                                                    |  |  |  |  |
| I EA           | Effective address.                                                                                                                                                                                                                        |  |  |  |  |
| F              | Floating-point accumulator.                                                                                                                                                                                                               |  |  |  |  |
| i <b>FAC</b>   | The single precision floating-point accumulator with 48 bits of mantissa and 16 bits of exponent.                                                                                                                                         |  |  |  |  |
| FAR            | Field address register.                                                                                                                                                                                                                   |  |  |  |  |
| FLR            | Field length register.                                                                                                                                                                                                                    |  |  |  |  |
| GRn            | A 32-bit general register, where n is 0 through 7.                                                                                                                                                                                        |  |  |  |  |
| Halfword       | A 16-bit unit of memory.                                                                                                                                                                                                                  |  |  |  |  |
| I I            | Indirect bit.                                                                                                                                                                                                                             |  |  |  |  |
| ,<br>I L       | The 32-bit L register.                                                                                                                                                                                                                    |  |  |  |  |
| <br>  LINK<br> | Bit 3 of the keys. Not used in S and R modes.                                                                                                                                                                                             |  |  |  |  |

| Table | 3–1  | (c | continued) |
|-------|------|----|------------|
| Dicti | onar | y  | Notation   |

| Symbol     | Meaning                                                                                                |
|------------|--------------------------------------------------------------------------------------------------------|
| Offset     | The number of halfwords from the starting address of a segment.                                        |
| I PB       | The procedure base register.                                                                           |
| i qac<br>I | The quad precision floating-point accumulator with 96<br>bits of mantissa and 16 bits of exponent.     |
| IR.        | A 32-bit general register.                                                                             |
|            | Bits 1 to 16 of a general register.                                                                    |
| skip       | Skip next 16-bit halfword before continuing execution.                                                 |
| I SR       | Source register (or index if memory reference).                                                        |
| I TM I     | Tag modifier. Bits used in I mode effective address calculation to specify indirection, indexing, etc. |
| X          | The X register (indexing).                                                                             |
| XB         | Auxiliary base register.                                                                               |
| Word       | A 32-bit unit of memory.                                                                               |
| I Y        | The Y register (indexing).                                                                             |
| m\n        | Specifies the number of bits, $\underline{n}$ , occupied by field $\underline{m}$ .                    |
|            | Specifies an optional argument.                                                                        |

# Resumable Instructions

Some assembly language instructions are resumable. When an interrupt is requested during the execution of an instruction, the processor usually services the interrupt at the end of execution before starting the next instruction. Some instructions, however, are too long or too complex for this to be desirable. When an interrupt is requested during one of these resumable instructions, the processor preserves the state of the interrupted instruction, handles the interrupt, then resumes the instruction at the point where the interrupt occurred. Table 3-2 lists the resumable assembly language instructions.

|                      |               | • • • • • •               |                            |                            | _              |  |  |
|----------------------|---------------|---------------------------|----------------------------|----------------------------|----------------|--|--|
| 1                    | Instructions  |                           |                            |                            |                |  |  |
| I AR<br>I XD<br>I XD | GT<br>TB<br>V | XAD<br>XDV<br>ZCM<br>ZMVD | XBID<br>XED<br>ZED<br>ZTPN | XCM<br>XMP<br>ZFIL<br>STFX | <br> <br> <br> |  |  |

Table 3-2 Resumable Instructions

These instructions depend on the settings in certain registers to determine whether they are being executed for the first or another time. In addition, some registers may be used for intermediate storage, modifying the previous contents as a side effect. Registers so modified are noted per instruction description.

#### Storing Data Into the 6350 and 9750 to 9955 II Instruction Stream

After any instruction that stores data into memory, you must wait five instructions before executing data. If in doubt about the next five instructions (temporally) to be executed, a mode change instruction to the current addressing mode, such as E32I, allows the stored data to be executed.

#### Instruction Formats

All I mode instructions belong to one of the following instruction types:

- I Mode Memory Reference
- I Mode Special Memory Reference
- I Mode Generic AP (Address Pointer)
- I Mode Register Generic
- I Mode Register Generic Branch
- Generic A and B (see below)

The format of each instruction type is shown in Figure 3-1.

Memory reference instructions have the opcode in bits 1 to 6. Special memory reference instructions (for floating point) have the opcode in bits 2, 3, 7, and 9; bit 8 specifies the floating accumulator. Some memory reference and special memory reference instructions have register-to-register and/or immediate forms. Such instructions are so identified in this I Mode Instruction Dictionary.

The immediate form of a memory reference instruction has a 16-bit literal in bits 17 to 32 instead of a 16-bit displacement. Register-to-register forms are 16 bits long, since they have no displacement. Bits 7 to 9 specify the destination register and bits 12 to 14 specify the source register.

The immediate form of a special memory reference instruction has a 16-bit encoding in bits 17 to 32 instead of a 16-bit displacement. The register-to-register form is 16 bits long, since it has no displacement. Bit 8 specifies the floating-point destination accumulator and bits 12 to 14 specify the index register or the floating-point source register (in bit 13).

Generic AP instructions have a generic format (where bits 10 to 16 contain the opcode extension) followed by a 32-bit address pointer.

Register generic instructions are 16 bits long and have an opcode in bits 10 to 16. The value of bits 1 to 6 is 011000; bits 7 to 9 specify a general register.

Register generic branch instructions are 32 bits long and have an opcode in bits 10 to 16. The value of bits 1 to 6 is 00100; bits 7 to 9 specify a general register. Bits 17 to 32 contain a displacement.

Generic A and B instructions that do not reference the A, B, E, or L registers are also used in I Mode. See Chapter 2, Figure 2-1 for the format of these instructions. Instructions defined in I mode for this class are included in this instruction dictionary.

 1
 67
 9 10 11 12
 14 15 16 17 32

 I
 OPCODE | DEST REG | TM | SOURCE REG OR INDEX | ER | DISP |

 I
 I Mode General Memory Reference Format\*

 \*
 This instruction type also has a register-to-register and immediate form as explained in the text.

I Mode Instruction Formats Figure 3-1

\_\_\_\_\_

1 1 2 3 4 6 7 8 9 10 11 12 14 15 16 17 32 1 1 - I I O I OP I 110 I OP I DES F I OP I TM ISRC REG OR IDXI BR I DISP I I I Mode Special Memory Reference (Floating Point) Format\* 1 2 3 4 6 7 9 10 11 12 14 15 16 17 32 | 1 | OP | 110 | OP | TM | REG OR INDEX | BR | DISPLACEMENT | I Mode Special Memory Reference (General Register) Format 1 16 | GENERIC OR REGISTER GENERIC | 17 20 21 22 23 24 25 32 33 48 | BIT | I | O | ER | 00000000 | OFFSET | I Mode Generic AP Format 67 910 16 1 | O11000 | REG | OPCODE | I Mode Register Generic Format 1 67 910 1617 32 | OO1OOO | REG | OPCODE | DISPLACEMENT | I Mode Register Generic Branch Format \* This instruction type also has a register-to-register and immediate form as explained in the text. 1

T

I Mode Instruction Formats Figure 3-1 (continued)

#### INSTRUCTIONS

A R, address Add Fullword 0 0 0 0 1 0 DR\3 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Fetches the 32-bit contents of the location specified by EA and adds them to the contents of the specified R. Stores the results in the specified R.

If the resulting sum is less than or equal to  $(2^{**31})-1$  and greater than or equal to  $-(2^{**31})$ , the instruction resets CBIT to 0. If the sum is greater than or equal to  $2^{**31}$ , an integer exception occurs. If the sum is less than or equal to  $-(2^{**31})-1$ , an integer exception occurs.

When an integer exception occurs, the results are of the opposite sign of the correct answer. In addition, the 32 bits are the 32 LSBs of the correct answer (that needs 33 bits to be correctly represented).

If an integer exception occurs and bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

At the end of the operation, LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

#### Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

ABQ r, address Add Entry to Bottom of Queue 0 1 1 0 0 0 R\3 1 0 1 1 1 0 0 AP\32

Adds the entry contained in the specified r to the bottom of the queue referenced by the AP. (AP points to the queue's QCB.) Sets the condition codes to reflect EQ if the queue was full, or to NE if not full. Leaves the values of CBIT and LINK unchanged.

► ACP destination-R, source-R Add C Pointer 101101DR\3 TM\2 SR\3 BR\2

Adds the two's complement number contained in the specified source R to the C language pointer in the specified destination R. Stores the result in the C pointer in the same destination R. Leaves the values of the CBIT, LINK, and condition codes unchanged.

Addition is done to segment-number offset byte, producing a new pointer with an updated segment-number offset byte. Adding a positive integer that causes the segment-number field to overflow will modify the ring field. Adding a negative integer that causes the segment-number field to underflow will also modify the ring field. R contents that do not cause the segment number to overflow will not modify the ring field. No overflow is detected or indicated.

#### Note

While of the memory referencing form, this instruction is only defined for register-to-register and immediate address formation. (See Appendix B.)

If ACP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

ADLR R Add LINK to Register 0 1 1 0 0 0 R\3 0 0 0 1 1 0 0

Adds the contents of LINK to the contents of R and stores the result in R. If there is an overflow, an integer exception occurs. If no integer exception occurs, CBIT is reset to O. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

AH r, address Add Halfword 0 0 1 0 1 0 DR\3 TM\2 SR\3 ER\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Fetches the 16-bit contents of the location specified by EA and adds them to the contents of the specified r. Stores the results in the specified r.

If the resulting sum is less than or equal to  $(2^{**15})-1$  and greater than or equal to  $-(2^{**15})$ , the instruction resets CBIT to 0. If the sum is greater than or equal to  $2^{**15}$ , an integer exception occurs. If the sum is less than or equal to  $-(2^{**15})-1$ , an integer exception occurs.

When an integer exception occurs, the results are of the opposite sign of the correct answer. In addition, the 16 bits are the 16 LSBs of the correct answer (that needs 17 bits to be correctly represented).

If an integer exception occurs and bit 8 of the keys contains a 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

At the end of the operation, LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

#### Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

AIP R, address
 Add Indirect Pointer
 1 1 1 0 1 DR\3 TM\2 SR\3 ER\2
 [ DISPLACEMENT\16 ]

Adds the value contained in the specified R to the 32-bit value contained in the location specified by EA. Stores the result in the specified R. Checks these contents for a pointer fault.

This pointer fault is generated when the contents of the memory location to be added to the specified R contain a pointer fault (bit 1 contains 1).

If this pointer fault occurs, the pointer to the memory location is saved in FADDR (SB + 11) as well as bits 1 to 16 of the contents of that memory location FOODEH (SB + 10). After completion of the fault handling mechanism, the instruction can be re-executed. (See Chapter 10 of the System Architecture Reference Guide.)

An overflow produces an integer exception. If no integer exception occurs, CBIT is reset to 0. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

### Note

AIP should weaken the ring field against the ring field of the effective address. This is not done on some current processors, but will be done on all future processors.

If AIP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

ARFA far, R
 Add Register to FAR
 0 1 1 0 0 0 R\3 1 1 1 FAR 0 0 1

Adds the bit address in the specified R to the contents of the specified FAR. Stores the result in the FAR. Leaves the values of CBIT and LINK indeterminate. Leaves the values of the condition codes unchanged.

ARGT

Argument Transfer 0 0 0 0 0 0 0 0 1 1 0 0 0 0 1 0 1

Transfers arguments from a source procedure to a destination procedure. ARGT is fetched and executed only when the argument transfer phase of a procedure call (PCL) instruction is interrupted or faulted.

To perform a procedure call and argument transfer, the source procedure must contain the PCL instruction followed by a number of argument templates. The destination procedure must begin with the ARGT instruction. When the PCL instruction is executed, control transfers to the destination procedure, and the ARGT instruction uses the templates to form the actual arguments. The arguments are stored in the new stack frame as they are computed. At the end of the ARGT instruction, the values of CBIT, LINK, and the condition codes are indeterminate.

ARGT must be the first executable instruction in any destination procedure that will use arguments. For those procedures whose entry control blocks specify zero arguments, you must omit ARGT or you will

destroy the return pointer for PCL, producing indeterminate results. For information about argument transfers, refer to the procedure calls section in Chapter 8 of the System Architecture Reference Guide.

ATQ r, address Add Entry to Top of Queue 0 1 1 0 0 0 R\3 1 0 1 1 1 0 1 AP\32

Adds the entry contained in the specified r to the top of the queue referenced by the AP. (AP points to the queue's QCB.) Sets the condition codes to reflect EQ if the queue was full, or to NE if not full. Leaves the values of CBIT and LINK unchanged.

BCEQ address Branch on Condition Code EQ 1 1 0 0 0 0 1 1 1 0 0 0 0 1 0 ADDRESS\16

If the condition codes reflect equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BCGE address Branch on Condition Code GE 1 1 0 0 0 0 1 1 1 0 0 0 0 1 0 1 ADDRESS\16

If the condition codes reflect greater than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BOGT address Branch on Condition Code GT 1 1 0 0 0 0 1 1 1 0 0 0 0 0 1 ADDRESS\16

If the condition codes reflect greater than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BCLE address Branch on Condition Code LE 1 1 0 0 0 0 1 1 1 0 0 0 0 0 0 ADDRESS\16

If the condition codes reflect less than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. BCLT address Branch on Condition Code LT 1 1 0 0 0 0 1 1 1 0 0 0 0 1 0 0 ADDRESS\16

If the condition codes reflect less than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BCNE address Branch on Condition Code NE 1 1 0 0 0 0 1 1 1 0 0 0 0 0 1 1 ADDRESS\16

If the condition codes reflect not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BCR address Branch on CBIT Reset to 0 1 1 0 0 0 0 1 1 1 1 0 0 0 1 0 1 ADDRESS\16

If CBIT has the value 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If CBIT has the value 1, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BCS address Branch on CBIT Set to 1 1 1 0 0 0 0 1 1 1 1 0 0 0 1 0 0 ADDRESS\16

If CBIT has the value 1, the instruction loads the specified address into the program counter. This address must be within the current segment. If CBIT has the value 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. BFEQ f, address Branch on Floating Accumulator Equal to 0 0 0 1 0 0 0 0 F 0 1 0 1 0 0 1 0 ADDRESS\16

If the specified floating accumulator contents are equal to 0, BFEQ loads the specified address (in the current segment) into the program counter; if they are not equal to 0, execution continues with the next instruction. The condition codes reflect the comparison. (See Appendix A.) Leaves the LINK and CBIT unchanged. BFEQ works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to 0 and less than 0. (See the System Architecture Reference Guide, Chapter 6.)

BFGE f, address Branch on Floating Accumulator Greater Than or Equal to 0 0 0 1 0 0 0 0 F 0 1 0 1 0 1 0 1 ADDRESS\16

If the specified floating accumulator contents are greater than or equal to 0, BFGE loads the specified address (in the current segment) into the program counter; if they are less than 0, execution continues with the next instruction. The condition codes reflect the comparison. (See Appendix A.) Leaves the LINK and CBIT unchanged. BFGE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to 0 and less than 0. (See the System Architecture Reference Guide, Chapter 6.)

BFGT f, address Branch on Floating Accumulator Greater Than 0 0 0 1 0 0 0 0 F 0 1 0 1 0 0 0 1 ADDRESS\16

If the specified floating accumulator contents are greater than 0, BFGT loads the specified address (in the current segment) into the program counter; if they are less than or equal to 0, execution continues with the next instruction. The condition codes reflect the comparison. (See Appendix A.) Leaves the LINK and CBIT unchanged. BFGT works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to 0 and less than 0. (See the System Architecture Reference Guide, Chapter 6.)

BFLE f, address Branch on Floating Accumulator Less Than or Equal to 0 001000F01010000 ADDRESS\16

If the specified floating accumulator contents are less than or equal to 0, BFLE loads the specified address (in the current segment) into the program counter; if they are greater than 0, execution continues with the next instruction. The condition codes reflect the comparison. (See Appendix A.) Leaves the LINK and CBIT unchanged. BFLE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to 0 and less than 0. (See Chapter 6 in the System Architecture Reference Guide.)

BFLT f, address Branch on Floating Accumulator Less Than 0 0 0 1 0 0 0 0 F 0 1 0 1 0 1 0 0 ADDRESS\16

If the specified floating accumulator contents are less than 0, BFLT loads the specified address (in the current segment) into the program counter; if they are greater than or equal to 0, execution continues with the next instruction. The condition codes reflect the comparison. (See Appendix A.) Leaves the LINK and CBIT unchanged. BFLT works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to 0 and less than 0. (See the System Architecture Reference Guide, Chapter 6.)

BFNE f, address Branch on Floating Accumulator Not Equal to 0 0 0 1 0 0 0 0 F 0 1 0 1 0 0 1 1 ADDRESS\16

If the specified floating accumulator contents are not equal to 0, BFNE loads the specified address (in the current segment) into the program counter; if they are equal to 0, execution continues with the next instruction. The condition codes reflect the comparison. (See Appendix A.) Leaves the LINK and CBIT unchanged. BFNE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to 0 and less than 0. (See the System Architecture Reference Guide, Chapter 6.)

EHD1 r, address Branch on Half Register Decremented by 1 0 0 1 0 0 0 R\3 1 1 0 0 1 0 0 ADDRESS\16

Decrements the specified r contents by 1 and stores the result in the specified r. If the decremented value is not equal to 0, BHD1 loads the specified address (in the current segment) into the program counter. If that value is equal to 0, execution continues with the next instruction. Leaves the CBIT, LINK, and condition codes unchanged.

BHD2 r,address Branch on Half Register Decremented By 2 0 0 1 0 0 0 R\3 1 1 0 0 1 0 1 ADDRESS\16

Decrements the specified r contents by 2 and stores the result in the specified r. If the decremented value is not equal to 0, BHD2 loads the specified address (in the current segment) into the program counter. If that value is equal to 0, execution continues with the next instruction. Leaves the CBIT, LINK, and condition codes unchanged.

BHD4 r, address Branch on Half Register Decremented By 4 0 0 1 0 0 0 R\3 1 1 0 0 1 1 0 ADDRESS\16

Decrements the specified r contents by 4 and stores the result in the specified r. If the decremented value is not equal to 0, BHD4 Loads the specified address (in the current segment) into the program counter. If that value is equal to 0, execution continues with the next instruction. Leaves the CBIT, LINK, and condition codes unchanged.

BHEQ r, address Branch on Half Register Equal To 0 0 0 1 0 0 0 R\3 1 0 0 1 0 1 0 ADDRESS\16

If the specified r contents are equal to 0, BHEQ loads the specified address (in the current segment) into the program counter; if they are not equal to 0, execution continues with the next instruction. Sets the condition codes to the comparison result. (See Appendix A.) Leaves the CBIT and LINK unchanged. EHGE r, address Branch on Half Register Greater Than or Equal To 0 0 0 1 0 0 0 R\3 1 0 0 1 1 0 1 ADDRESS\16

If the specified r contents are greater than or equal to 0, EHGE loads the specified address (in the current segment) into the program counter; if they are less than 0, execution continues with the next instruction. Sets the condition codes to the result comparison. (See Appendix A.) Leaves the CBIT and LINK unchanged.

BHGT r, address Branch on Half Register Greater Than 0 0 0 1 0 0 0 R\3 1 0 0 1 0 0 1 ADDRESS\16

If the contents of the specified r are greater than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the contents of r are less than or equal to 0, execution continues with the next instruction. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the values of CBIT and LINK unchanged.

EHI1 r, address Branch on Half Register Incremented by 1 0 0 1 0 0 0 R\3 1 1 0 0 0 0 ADDRESS\16

Increments the contents of the specified r by 1 and stores the result in the specified r. If the incremented value is not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the incremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EH12 r, address Branch on Half Register Incremented by 2 0 0 1 0 0 0 R\3 1 1 0 0 0 0 1 ADDRESS\16

Increments the contents of the specified r by 2 and stores the result in the specified r. If the incremented value is not equal to 0, the instruction loads the the specified address into the program counter. This address must be within the current segment. If the incremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. BHI4 r, address Branch on Half Register Incremented by 4 0 0 1 0 0 0 R\3 1 1 0 0 0 1 0 ADDRESS\16

Increments the contents of the specified r by 4 and stores the result in the specified r. If the incremented value is not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the incremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BHLE r, address Branch on Half Register Less Than or Equal to 0 0 0 1 0 0 0 R\3 1 0 0 1 0 0 0 ADDRESS\16

If the contents of the specified r are less than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the contents of r are greater than 0, execution continues with the next instruction. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the values of CBIT and LINK unchanged.

BHLT r, address Branch on Half Register Less Than 0 0 0 1 0 0 0 R\3 1 0 0 1 1 0 0 ADDRESS\16

If the contents of the specified r are less than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the contents of r are greater than or equal to 0, execution continues with the next instruction. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the values of CBIT and LINK unchanged.

BHNE r,address Branch on Half Register Not Equal To 0 0 0 1 0 0 0 R\3 1 0 0 1 0 1 1 ADDRESS\16

If the contents of the specified r are not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the contents of r are equal to 0, execution continues with the next instruction. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the values of CBIT and LINK unchanged. BLR address Branch on LINK Reset to O 1100001111000111 ADDRESS\16

If LINK has the value 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If LINK has the value 1, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BLS address Branch on LINK Set to 1 1100001111000110 ADDRESS\16

If LINK has the value 1, the instruction loads the specified address into the program counter. This address must be within the current segment. If LINK has the value 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.



BMEQ address Branch on Magnitude Condition EQ 1100001110000010 ADDRESS\16

If the condition codes indicate magnitude equal to 0, the instruction loads the specified address into the program counter, like BCEQ. BMEQ is intended for magnitude comparisons after a compare or subtract instruction. This address must be within the current segment. If the condition codes indicate some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BMGE address Branch on Magnitude Condition GE 1100001111000110 ADDRESS\16

If LINK has the value 1, the instruction loads the specified address into the program counter, like BLS. EMGE is used to determine if the magnitude of the register quantity was greater than or equal to the memory quantity after a compare or subtract instruction. This address must be within the current segment. If LINK has the value 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EMGT address Branch on Magnitude Condition GT 1 1 0 0 0 0 1 1 1 1 0 0 1 0 0 0 ADDRESS\16

If LINK is 1 and the condition codes reflect not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If some other condition exists, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BMLE address Branch on Magnitude Condition LE 1 1 0 0 0 0 1 1 1 1 0 0 1 0 0 1 ADDRESS\16

If LINK is 0 or the condition codes reflect equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If some other condition exists, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BMLT address Branch on Magnitude Condition LT 1 1 0 0 0 0 1 1 1 1 0 0 0 1 1 1 ADDRESS\16

If LINK has the value 0, the instruction loads the specified address into the program counter, like BLR. BMLT is used to determine if the magnitude of the register quantity is less than the memory quantity after a compare or subtract instruction. This address must be within the current segment. If LINK has the value 1, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EMNE address Branch on Magnitude Condition NE 1 1 0 0 0 0 1 1 1 0 0 0 0 0 1 1 (V mode form) ADDRESS\16

If the condition codes indicate magnitude not equal to 0, the instruction loads the specified address into the program counter, like BCNE. EMNE is intended for magnitude comparisons after a compare or subtract instruction. This address must be within the current segment. If the condition codes reflect some other condition, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BRBR R, bit #, address Branch on Register Bit Reset 0 0 1 0 0 0 R\3 0 1 BIT\5 ADDRESS\16

Bits 12 to 16 of the instruction contain a value between '00 and '37. This value specifies the bit position in the register to be tested. A value of '00 corresponds to bit 1; '01, bit 2; and so on.

If the specified bit position contains 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the specified bit position contains 1, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BRBS R, bit #, address Branch on Register Bit Set 0 0 1 0 0 0 R\3 0 0 BIT\5 ADDRESS\16

Bits 12 to 16 of the instruction contain a value between '00 and '37. This value specifies the bit position in the register to be tested. A value of '00 corresponds to bit 1; '01, bit 2; and so on.

If the specified bit position contains 1, the instruction loads the specified address into the program counter. This address must be within the current segment. If the specified bit position contains 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BRD1 R, address Branch on Register Decremented by 1 0 0 1 0 0 0 R\3 1 0 1 1 1 0 0 ADDRESS\16

Decrements the contents of the specified R by 1 and stores the result in the specified R. If the decremented value is not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the decremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. ERD2 R, address Branch on Register Decremented by 2 0 0 1 0 0 0 R\3 1 0 1 1 1 0 1 ADDRESS\16

Decrements the contents of the specified R by 2 and stores the result in the specified R. If the decremented value is not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the decremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BRD4 R, address Branch on Register Decremented by 4 0 0 1 0 0 0 R\3 1 0 1 1 1 1 0 ADDRESS\16

Decrements the contents of the specified R by 4 and stores the result in the specified R. If the decremented value is not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the decremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EREQ R, address Branch on Register Equal to 0 0 0 1 0 0 0 R\3 1 0 0 0 0 1 0 ADDRESS\16

If the contents of the specified R are equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the R contents are not equal to 0, execution continues with the next instruction. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the values of CBIT and LINK unchanged.

ERGE R, address Branch on Register Greater Than or Equal to 0 0 0 1 0 0 0 R\3 1 0 0 0 1 0 1 ADDRESS\16

If the contents of the specified R are greater than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the R contents are less than 0, execution continues with the next instruction. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the values of CBIT and LINK unchanged.

BRGT R, address Branch on Register Greater Than O 00100R\3100001 ADDRESS\16

If the contents of the specified R are greater than 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the R contents are less than or equal to 0, execution continues with the next instruction. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the values of CBIT and LINK unchanged.

BRI1 R, address Branch on Register Incremented by 1 0 0 1 0 0 0 R\3 1 0 1 1 0 0 0 ADDRESS\16

Increments the contents of the specified R by 1 and stores the result in the specified R. If the incremented value is not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the incremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BRI2 R, address Branch on Register Incremented by 2 001000R\31011001 ADDRESS\16

Increments the contents of the specified R by 2 and stores the result in the specified R. If the incremented value is not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the incremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

BRI4 R, address Branch on Register Incremented by 4 0 0 1 0 0 0 R\3 1 0 1 1 0 1 0 ADDRESS\16

Increments the contents of the specified R by 4 and stores the result in the specified R. If the incremented value is not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the incremented value is equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ERLE R, address Branch on Register Less Than or Equal to 0 0 0 1 0 0 0 R\3 1 0 0 0 0 0 ADDRESS\16

If the contents of the specified R are less than or equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the R contents are greater than 0, execution continues with the next instruction. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the values of CBIT and LINK unchanged.

ERLT R, address Branch on Register Less Than 0 0 0 1 0 0 0 R\3 1 0 0 0 1 0 0 ADDRESS\16

If the contents of the specified R are less than O, the instruction loads the specified address into the program counter. This address must be within the current segment. If the R contents are greater than or equal to O, execution continues with the next instruction. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the values of CBIT and LINK unchanged.

ERNE R, address Branch on Register Not Equal to 0 0 0 1 0 0 0 R\3 1 0 0 0 0 1 1 ADDRESS\16

If the contents of the specified R are not equal to 0, the instruction loads the specified address into the program counter. This address must be within the current segment. If the R contents are equal to 0, execution continues with the next instruction. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the values of CBIT and LINK unchanged.

3-24

CR, address Compare Fullword 1 1 0 0 0 1 DR\3 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Compares the 32-bit value contained in the specified R to the 32-bit value contained in the location specified by EA. The comparison is done by subtracting the contents of the the memory location from the contents of the register. Sets the condition codes to the result of the comparison. (See Appendix A.) Leaves the value of CBIT unchanged. LINK contains the carry-out bit.

Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

CALF address
 Call Fault Handler
 0 0 0 0 0 0 0 1 1 1 0 0 0 1 0 1
 AP\32

The address pointer in this instruction points to the ECB of a fault routine. CALF uses this pointer to transfer control to the fault routine as if the transfer were a normal procedure call with no arguments passed. The values of CBIT, LINK, and the condition codes are indeterminate. See Chapter 10 of the <u>System Architecture Reference</u> Guide for more information.

CCP destination-R, source-R Compare C Pointer 1 0 0 1 0 1 DR\3 TM\2 SR\3 BR\2

Compares the C language pointer in the specified source R to the C language pointer in the specified destination R. Ignores the pointer fault and ring bits during the comparison. Leaves the values of CBIT and LINK unchanged. Sets the condition codes to the outcome of the comparison as follows.

| Condition |    |               |   |          |    | $\underline{\alpha}$ |               |
|-----------|----|---------------|---|----------|----|----------------------|---------------|
| Contents  | of | destination-R | > | contents | of | source-R.            | GT            |
| Contents  | of | destination-R | = | contents | of | source-R.            | eq            |
| Contents  | of | destination-R | < | contents | of | source-R.            | $\mathbf{LT}$ |

#### Note

While of the memory referencing form, the CCP instruction is only defined for register-to-register address formation. (See Appendix B of the <u>Instruction Sets Guide</u>.) The immediate form of this instruction is <u>undefined</u>, but the preferred implementation is a UII for the immediate form.

If CCP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

CGT r Computed GOTO 0 1 1 0 0 0 R\3 0 0 1 0 1 1 0 INTEGER N\16 BRANCH ADDRESS 1\16 ... BRANCH ADDRESS N-1\16

If the contents of the specified r are greater than or equal to 1 and less than the specified integer N that follows the opcode, the instruction adds the contents of r to the contents of the program counter to form an address. (The program counter points to the integer N following the opcode.) Loads the contents of the location specified by this address into the program counter. If the contents of r are not within this range, the instruction adds integer N to the contents of the program counter and stores the result in the program counter. Each of the branch addresses following the instruction specifies a location within the current procedure segment. The values of CBIT, LINK, and the condition codes are indeterminate.

CH r, address Compare Halfword 1 1 1 0 0 1 DR\3 TM\2 SR\2 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Compares the value contained in the specified r to the 16-bit value contained in the location specified by EA. Leaves the value of CBIT unchanged. LINK contains the carry-out bit. The condition codes reflect the result of the comparison. (See Appendix A.)

#### Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

CHS R Change Sign 0 1 1 0 0 0 R\3 0 1 0 0 0 0

Complements bit 1 of the specified R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CMH r Complement r 011000R\30100101

Forms the one's complement of the contents of the specified r by inverting the value of each bit and stores the result in r. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CMR R Complement R 0 1 1 0 0 0 R\3 0 1 0 0 1 0 0

Forms the one's complement of the contents of the specified R by inverting the value of each bit and stores the result in R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CR R Clear R to 0 0 1 1 0 0 0 R\3 0 1 0 1 1 1 0

Clears the specified R to O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CREL R Clear R High Byte 1 Left 0 1 1 0 0 0 R\3 0 1 1 0 0 1 0

Loads zeros into bits 1 to 8 of the specified R. Leaves the values of LINK, CBIT, and the condition codes unchanged.

CRBR R Clear R High Byte 2 Right 0 1 1 0 0 0 R\3 0 1 1 0 0 1 1

Loads zeros into bits 9 to 16 of the specified R. Leaves the values of LINK, CBIT, and the condition codes unchanged.

CRHL R Clear R Left Halfword 0 1 1 0 0 0 R\3 0 1 0 1 1 0 0

Clears bits 1 to 16 of the specified R to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CRHR R Clear R Right Halfword 0 1 1 0 0 0 R\3 0 1 0 1 1 0 1

Clears bits 17 to 32 of the specified R to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

CSR R Copy Sign 0 1 1 0 0 0 R\3 0 1 0 0 0 0 1

Copies the value of bit 1 of the specified R into CBIT, and then loads 0 into bit 1 of R. The value of LINK is indeterminate. Leaves the condition codes unchanged.

D R, address Divide Fullword 1 1 0 0 1 0 DR\3 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Divides the 64-bit value contained in the specified R and R+1 by the 32-bit value contained in the location specified by EA. Stores the quotient in the specified R and the remainder in R+1. Overflow may occur if the quotient is less than  $-(2^{*}31)$  or greater than  $(2^{*}31)-1$ . Overflow and divide by 0 cause an integer exception.

If no integer exception occurs, CBIT is reset to 0. The instruction leaves the values of LINK and the condition codes indeterminate.

If an integer exception occurs and bit 8 in the keys contains 0, the instruction sets CBIT to 1; if bit 8 contains 1, the instruction sets CBIT to 1 and causes an integer exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

Note

R must specify an even register. This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

DBLE f Convert Single to Double Floating Point 0 1 1 0 0 0 0 F 0 1 0 0 0 1 1 0

Converts the single precision number in the specified floating-point accumulator to a double precision one by zeroing bits 32 to 48 of the floating-point accumulator. Stores the result in the floating-point accumulator. Leaves the values of CBIT, LINK, and the condition codes unchanged. Overflow or underflow cannot occur.

DCP R Decrement C Pointer 0 1 1 0 0 0 R\3 1 1 1 0 0 0 0

Decrements the C language pointer in the specified R by 1 byte. Decrementing a O offset reduces the segment number by 1. Decrementing segment number O, offset O, byte O generates a pointer to the maximum segment number, the maximum offset, and byte O. Leaves the CBIT, LINK, and the condition codes unchanged. For C pointer details, see Chapter 1 and Appendix B of this guide.

#### Note

If DCP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

DFA f, address
 Double Floating Add
 0 0 1 1 1 0 1 F 1 TM\2 SR\3 BR\2
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Adds the contents of the specified DAC to the contents of the location specified by EA. Stores the result in the DAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide.

#### Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

DFC f, address
 Double Floating Compare
 0 0 0 1 1 0 1 F 1 TM\2 SR\3 BR\2
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Compares the contents of the specified DAC to the contents of the location specified by EA. Leaves the values of CBIT and LINK unchanged. Sets the condition codes to the outcome of the comparison.

# $\frac{\text{Condition}}{\text{Contents of DAC} > \text{contents of location specified by EA.} \qquad \text{GT}$ Contents of DAC = contents of location specified by EA. EQ Contents of DAC < contents of location specified by EA. LT

On some processors, DFC works correctly only on normalized numbers as follows. The comparison has a maximum of three sequential stages:
first the signs, then the exponents, and finally the fractions of the two numbers are compared for equality. If the comparison during any one of these stages reveals an inequality, the results are returned and the instruction ends. Unnormalized numbers are unexpected and produce unexpected results. Other processors actually perform a subtract, resulting in a proper comparison.

## Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

DFCM f Double Floating Complement 0 1 1 0 0 0 0 F 0 1 1 0 0 1 0 0

Forms the two's complement of the double precision, floating-point number contained in the specified DAC and normalizes it if necessary. Stores the result in the DAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 in the keys contains 1, the instruction sets CBIT to 1. If bit 7 contains 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

DFD f,address Double Floating Divide 0 1 1 1 1 0 0 F 1 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Divides the contents of the specified DAC by the contents of the location specified by EA. Normalizes the quotient if necessary. Stores the result in the DAC. An overflow or divide by to causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 in the keys contains 1, the instruction sets CBIT to 1. If bit 7 contains 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

### Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

DFL f, address
 Double Floating Load
 0 0 0 1 1 0 0 F 1 TM\2 SR\3 BR\2
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Loads the 64-bit contents of the location specified by EA into the specified DAC without normalizing the result. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

The DFL instruction also has a register-to-register and an immediate form. See Appendix B for more information.

DFM f, address Double Floating Multiply 0 1 0 1 1 0 1 F 1 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Multiplies the 64-bit contents of the location specified by EA by the contents of the specified DAC. Normalizes the result if necessary. Stores the result in the DAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 in the keys contains 1, the instruction sets CBIT to 1. If bit 7 contains 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

DFS f, address
 Double Floating Subtract
 0 1 0 1 1 0 0 F 1 TM\2 SR\3 BR\2
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Subtracts the 64-bit contents of the location specified by EA from the contents of the specified DAC. Stores the result in the DAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate. For 750 and 850 processors, exponent underflow is detected, but exponent overflow is not.

If a floating-point exception occurs and bit 7 in the keys contains 1, the instruction sets CBIT to 1. If bit 7 contains 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

# Note

The DFS instruction also has a register-to-register and an immediate form. See Appendix B for more information.

DFST f, address Double Floating Point Store 0 0 1 1 1 0 0 F 1 TM\2 SR\3 BR\2 DISPLACEMENT\16

Calculates an effective address, EA. Stores the contents of the specified DAC into the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This instruction does not normalize the result before loading it into the specified memory location.

DH R, address Divide Halfword 1 1 1 0 1 0 DR\3 TM\2 SR\3 ER\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Divides the 32-bit dividend contained in the specified R by the 16-bit value contained in the location specified by EA. Stores the quotient in bits 1 to 16 of R and the remainder in bits 17 to 32 of R. The sign of the remainder equals the sign of the dividend. If the quotient is less than  $-(2^{**15})$  or greater than  $(2^{**15})-1$ , an overflow occurs and causes an integer exception. If no integer exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If an integer exception occurs and bit 8 in the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains 1, the instruction sets CBIT to 1 and causes an integer exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

## Note

The DH instruction also has a register-to-register and an immediate form. See Appendix B for more information.

DH1 r Decrement r by 1 0 1 1 0 0 0 R\3 1 0 1 1 0 0 0

Decrements the contents of r by 1 and stores the result in r. If an overflow occurs, an integer exception occurs. If no integer exception occurs, CBIT is reset to 0. LINK reflects the value of the carry. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

DH2 r Decrement r by 2 0 1 1 0 0 0 R\3 1 0 1 1 0 0 1

Decrements the contents of r by 2 and stores the result in r. If an overflow occurs, an integer exception occurs. If no integer exception occurs, CBIT is reset to 0. LINK reflects the value of the carry. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the DH2 instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

DM address Decrement Memory Fullword 1 1 0 1 1 0 0 0 0 TM\2 SR\3 BR\2 DISPLACEMENT\16

Subtracts 1 from the 32-bit integer contained in the specified location and stores the result back in the specified location. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the operation. (See Appendix A.) DMH address Decrement Memory Halfword 1 1 1 1 1 0 0 0 0 TM\2 SR\3 BR\2 DISPLACEMENT\16

Subtracts 1 from the 16-bit integer contained in the specified location and stores the result back in the specified location. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the operation. (See Appendix A.)

DR1 R Decrement Register by 1 0 1 1 0 0 0 R\3 1 0 1 0 1 0 0

Decrements the contents of R by 1 and stores the result in R. An overflow causes an integer exception. If no integer exception occurs, CBIT is reset to 0. LINK contains the value of the borrow bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

DR2 R Decrement Register by 2 0 1 1 0 0 0 R\3 1 0 1 0 1 0 1

Decrements the contents of the specified R by 2 and stores the result in R. An overflow causes an integer exception. If no integer exception occurs, CBIT is reset to 0. LINK contains the value of the borrow bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the DR2 instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

DRN Double Round From Quad 0 1 0 0 0 0 0 0 1 1 0 0 0 0 0 0

Converts the 112-bit value in QAC to a double precision floating-point number. If QAC contains 0, the instruction ends. If bits 50 to 96 of QAC are not zero, or bit 48 of QAC contains 1, the instruction adds the value of bit 49 to that of bit 48 (unbiased round) and clears bits 49 to 96 of QAC to 0. If any other condition exists, no unbiased rounding occurs, but bits 49 to 96 of QAC are still cleared to 0. After any rounding and clearing occurs, the instruction normalizes the result and loads it into bits 1 to 64 of QAC.

If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

#### Note

If DRN is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

# DRNM

Double Round From Quad Towards Negative Infinity 1 1 0 0 0 0 0 1 0 1 1 1 1 0 0 1

Converts the 112-bit value in QAC to a double precision floating-point number. If QAC contains 0, or if bits 49 to 96 of QAC contain zeros, the instruction ends. In any other case, the instruction clears bits 49 to 96 to 0, normalizes the result, and places it in bits 1 to 64 of QAC.

The value of CBIT is unchanged. The values of LINK and the condition codes are indeterminate.

#### Note

If DRNM is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

## DRNP

Double Round From Quad Towards Positive Infinity 0 1 0 0 0 0 0 0 1 1 0 0 0 0 0 1

Converts the 112-bit value in QAC to a double precision floating point number. If QAC contains 0, or if bits 49 to 96 of QAC contain zeros, the instruction ends. In any other case, the instruction adds 1 to the value contained in bit 48 of QAC, clears bits 49 to 96 to 0, normalizes the result, and places it in bits 1 to 64 of QAC. If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

#### Note

If DRNP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

DRNZ Double Round From Quad Towards Zero 0 1 0 0 0 0 0 0 1 1 0 0 0 0 1 0

Converts the 112-bit value in QAC to a double precision floating-point number. If QAC contains 0, the instruction ends. If bits 49 to 96 of QAC contain zeros and bit 1 contains 1, the instruction adds 1 to the value contained in bit 48 of QAC, clears bits 49 to 96 to 0, normalizes the result, and places it in bits 1 to 64 of QAC. If any other condition exists, no rounding occurs.

If no floating-point exception occurs, the instruction resets CBIT to O. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

Note

If DRNZ is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.) E16S Enter 16S Mode 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1

Sets bits 4 to 6 of the keys to 000. Subsequent S mode instructions may now be interpreted, and 16S address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

E32I Enter 32I Mode 0 0 0 0 0 0 1 0 0 0 0 1 0 0 0

Sets bits 4 to 6 of the keys to 100. Subsequent I mode instructions may now be interpreted, and 32I address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

E32R Enter 32R Mode 0 0 0 0 0 0 1 0 0 0 0 1 0 1 1

Sets bits 4 to 6 of the keys to Oll. Subsequent R mode instructions may now be interpreted, and 32R address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

E32S Enter 32S Mode 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 1

Sets bits 4 to 6 of the keys to 001. Subsequent S mode instructions may now be interpreted, and 32S address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

E64R Enter 64R Mode 0 0 0 0 0 0 1 0 0 0 0 1 0 0 1

Sets bits 4 to 6 of the keys to 010. Subsequent R mode instructions may now be interpreted, and 64R address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged. E64V Enter 64V Mode 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0

Sets bits 4 to 6 of the keys to 110. Subsequent V mode instructions may now be interpreted, and 64V address calculations may be used to form effective addresses. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EAFA far, address Effective Address to FAR 0 0 0 0 0 0 1 0 1 1 0 0 F 0 0 0 AP\32

Builds a 36-bit EA from the 32-bit address pointer contained in the instruction and loads it into the specified FAR. The AP bit field is processed and loaded into the bit portion of the FAR, for direct access. Indirection uses the bit field in the indirect pointer (if any). Leaves the values of CBIT, LINK, and the condition codes unchanged.

Figure 3-2 shows the format of the EA loaded into the specified FAR.

1 16 17 32 33 36 RING, SEG | WORD # | BIT # |

> EA Format for EAFA Figure 3-2

EALB address Effective Address to LB 1 0 0 1 1 0 0 1 0 TM\2 SR\3 BR\2 DISPLACEMENT\16

Calculates an effective address, EA, and loads it into LB. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EAR R, address Effective Address to Register 1 1 0 0 1 1 DR\3 TM\2 SR\3 ER\2 DISPLACEMENT\16

Calculates an effective address, EA. Loads the 32-bit EA into the specified R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EAXB address
 Effective Address to XB
 1 0 1 1 1 0 0 1 0 TM\2 SR\3 ER\2
 DISPLACEMENT\16

Calculates an effective address, EA, and loads it into XB. Leaves the values of CBIT, LINK, and the condition codes unchanged.

EIO(address [Spor 403;7647] Execute I/O 0 1 1 1 0 0 DR\3 TM\2 SR\3 BR\2 DISPLACEMENT\16

Calculates an effective address, EA. Executes bits 17 to 32 of EA as if they were a PIO instruction. If execution is successful, the instruction sets the condition codes as follows:

<u>OC</u> <u>Meaning</u> EQ Successful INA, OTA, or SKS instruction

NE Unsuccessful INA, OTA, OR SKS; any OCP

Leaves the values of LINK and CBIT unchanged. For more information about I/O operations, see Chapter 11 of the <u>System Architecture</u> Reference Guide.

Note

# ENB Enable Interrupts 0 0 0 0 0 0 0 1 0 0 0 0 0 0 1

Enables interrupts by setting bit 1 of the modals to 1. Inhibits interrupts for one instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

This is a restricted instruction.

ENEL Enable Interrupts (Local) 0 0 0 0 0 0 0 1 0 0 0 0 0 0 1

This 850 instruction performs the same actions as ENB, except that it is performed specifically for the local processor. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

# This is a restricted instruction.

ENBM

Enable Interrupts (Mutual) 000000010000000

For the 850, a processor checks the availability of the mutual exclusion lock. If available, the processor releases this lock and enables interrupts. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

ENBP Enable Interrupts (Process) 0 0 0 0 0 0 0 1 0 0 0 0 0 1 0

For the 850, a processor checks the availability of the process exchange lock. If available, the process releases this lock and enables interrupts. Leaves the values of CBIT, LINK, and the condition codes unchanged.

Note

FA f, address
 Floating Add
 0 0 1 1 1 0 1 F 0 TM\2 SR\3 ER\2
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Adds the contents of the specified FAC to the 32-bit contents of the location specified by EA. (See Chapter 6 of the System Architecture Reference Guide.) Stores the result in the FAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate. If a floating-point exception sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide.

## Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

FC f, address Floating Compare 0 0 0 1 1 0 1 F 0 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Compares the contents of the specified FAC to the contents of the location specified by EA. Leaves the values of LINK and CBIT unchanged. Sets the condition codes to reflect the outcome of the comparison:

## Condition

Contents of FAC > contents of location specified by EA. GT

Contents of FAC = contents of location specified by EA. EQ

Contents of FAC < contents of location specified by EA.

On some processors, FC works correctly only on normalized numbers as follows. The comparison has a maximum of three sequential stages: first the signs, then the exponents, and finally the fractions of the two numbers are compared for equality. If the comparison during any one of these stages reveals an inequality, the results are returned and the instruction ends. Unnormalized numbers are unexpected and produce unexpected results. Other processors actually perform a subtract, resulting in a proper comparison.

#### Note

The FC instruction also has a register-to-register and an immediate form. See Appendix B for more information.

 $\infty$ 

# FCDQ

Floating Point Convert Double to Quad 1100000101111001

Clears FAC1 to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

If FCDQ is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

# FCM f Floating Point Complement 0 1 1 0 0 0 0 F 0 1 0 0 0 0 0 0

Forms the two's complement of the contents of the FAC and normalizes the result if necessary. (See Chapter 6 of the System Architecture Reference Guide.) Stores the result in the FAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 in the keys contains 1, the instruction sets CBIT to 1. If bit 7 contains 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

FD f, address Floating Divide 0 1 1 1 1 0 0 F 0 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Divides the contents of the specified FAC by the contents of the location specified by EA. (See Chapter 6 of the System Architecture Reference Guide.) Stores the result in the FAC and normalizes if necessary. A divide by 0 or an overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 in the keys contains 1, the instruction sets CBIT to 1. If bit 7 contains 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

### Note

The FD instruction also has a register-to-register and an immediate form. See Appendix B for more information.

FL f, address Floating Load  $0\ 0\ 0\ 1\ 1\ 0\ 0\ F\ 0\ TM \ SR \ SR \ BR \ 2$ [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Converts the single precision operand to double precision and loads the result into the specified FAC without normalizing it. Leaves the contents of CBIT, LINK, and the condition codes unchanged.

# Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

FLT f,R Convert Integer to Floating Point 0 1 1 0 0 0 R\3 1 0 0 F 1 0 1

Converts the integer contained in R to a floating-point number and stores the result in the specified FAC. The values of CBIT, LINK, and the condition codes are indeterminate.

FLTH f,r

Convert Halfword Integer to Floating Point 0 1 1 0 0 0 R\3 1 0 0 F 0 1 0

Converts the halfword integer contained in r to a floating-point number and stores the result in the specified FAC. The values of CBIT, LINK, and the condition codes are indeterminate.

FM f, address Floating Multiply  $0 1 0 1 1 0 1 F 0 TM \ SR \ BR \ 2$ [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Multiplies the 32-bit contents of the location specified by EA by the contents of the specified FAC. (See Chapter 6 of the System Architecture Reference Guide.) Normalizes the result, if necessary, and stores it in the FAC. An exponent overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 in the keys contains 1, the instruction sets CBIT to 1. If bit 7 contains 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

## Note

The FM instruction also has a register-to-register and an immediate form. See Appendix B for more information.

FRN f Floating Round 0 1 1 0 0 0 0 F 0 1 0 0 0 1 1 1

This instruction operates on and stores all results in the floating accumulator.

For the 2350 to 9955 II, the following actions occur. If bits 1 to 48 contain 0, then bits 49 to 64 are cleared to 0. If bits 24 and 25 both contain 1, then 1 is added to bit 24, bits 25 to 48 are cleared to 0, and the result is normalized. If bit 25 contains 1 and bits 26 to 48 are not equal to 0, then 1 is added to bit 24, bits 25 to 48 are cleared, and the result is normalized.

For the earlier systems listed in "About This Book", the following actions occur. If bits 1 to 48 contain 0, then bits 49 to 64 are cleared to 0. Otherwise, bit 25 is added to bit 24, bits 25 to 48 are cleared to 0, and the result is normalized.

For all systems, if no floating-point exception occurs, resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

FRNM f FLoating Point Round Towards Negative Infinity 0 1 1 0 0 0 0 F 0 1 1 0 0 1 1 0

Converts the 64-bit value in DAC to a single precision floating-point number. If DAC contains 0, or if bits 25 to 48 of DAC contain zeros, the instruction ends. In any other case, the instruction clears bits 25 to 48 to 0, normalizes the result, and places it in DAC.

If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

FRNP f Floating Point Round Towards Positive Infinity 0 1 1 0 0 0 0 F 0 1 1 0 0 1 0 1

Converts the 64-bit value in DAC to a single precision floating-point number. If DAC contains 0, or if bits 25 to 48 of DAC contain zeros, the instruction ends. In any other case, the instruction adds 1 to the value contained in bit 24 of DAC, clears bits 25 to 48 to 0, normalizes the result, and places it in DAC.

If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

FRNZ f Floating Point Round Towards Zero 0 1 1 0 0 0 0 F 0 1 1 0 0 1 1 1

Converts the 64-bit value in DAC to a single precision floating-point number. If DAC contains 0, the instruction ends. If bits 25 to 48 of DAC are not zeros and bit 1 contains 1, the instruction adds 1 to the value contained in bit 24 of DAC, clears bits 25 to 48 to 0, normalizes the result, and places it in DAC. If any other condition exists, no rounding occurs.

If no floating-point exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, FRNZ sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

FS f, address
 Floating Subtract
 0 1 0 1 1 0 0 F 0 TM\2 SR\3 BR\2
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Subtracts the 32-bit contents of the location specified by EA from the contents of the specified FAC. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Normalizes the result, if necessary, and stores it in the FAC. An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

## Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

FST f, address
 Floating Store
 0 0 1 1 1 0 0 F 0 TM\2 SR\3 ER\2
 DISPLACEMENT\16

Calculates an effective address, EA. Stores the contents of the specified FAC into the 32-bit location specified by EA. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) The result is normalized only if rounding is enabled. If the exponent contained in the FAC is too large to be expressed in 8 bits, a floating-point exception (store exception) occurs. If no exception occurs, the instruction resets CBIT to 0. At the end of the instruction, the values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information. In either case, a floating-point exception leaves the contents of the memory location in an indeterminate state.

# 

Halts computer operation. The program counter points to the instruction that would have been executed if execution had not been stopped. The supervisor terminal indicates a halt. Leaves the values of CBIT, LINK, and the condition codes unchanged.

This instruction saves the contents of registers in a memory location specified by the RSAVPTR. The contents of RSAVPTR can be accessed by an LDAR/STAR instruction with address '40037. The registers are saved in their physical order. (See Chapter 9 of the System Architecture Reference Guide for the format of these register files.) The saved register file order is shown in Table 3-3.

| 6350,<br>  9750 to 9955 II<br>                                                                                                                                           | 2350 to 2755,<br>  9650 and 9655                                                                                                                                                                                                                                                                                         |                |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| User Reg Set 3<br>User Reg Set 4<br>User Reg Set 1<br>User Reg Set 2<br>Microcode Reg File,<br>Set 2<br>Indirect Reg Set<br>Microcode Reg File,<br>Set 1<br>DMx Reg File | <ul> <li>User Reg Set 1</li> <li>User Reg Set 2</li> <li>User Reg Set 3</li> <li>User Reg Set 4</li> <li>User Reg Set 5</li> <li>User Reg Set 6</li> <li>User Reg Set 7</li> <li>User Reg Set 8</li> <li>DMx Reg File</li> <li>Microcode Reg File,</li> <li>Set 1</li> <li>Microcode Reg File,</li> <li>Set 2</li> </ul> | User Reg Set 2 |
|                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                          |                |

# Table 3-3 Order of Saved Registers After HLT

\* The earlier systems are listed in "About This Book". Of these, the 850 has two ISPs. For each ISP, the order of saved registers is identical to the order shown for the rest of the 50 Series.

Note

I R, address Interchange Register and Memory Fullword 1 0 0 0 1 DR\3 TM\2 SR\3 ER\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Interchanges the 32-bit value contained in the specified R with the 32-bit value contained in the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

The I instruction is non-atomic, and, especially for dual-stream processors, cannot be used for spin-locks. In these cases, use the STCD instruction instead.

This instruction also has a register-to-register form. See Appendix B for more information.

ICBL r

Interchange Bytes and Clear Left  $0 1 1 0 0 0 R \setminus 3 0 1 1 0 1 0 1$ 

Interchanges bits 1 to 8 and bits 9 to 16 of the specified r, then loads 0 into bits 1 to 8 of r. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ICBR r Interchange Bytes and Clear Right 0 1 1 0 0 0 R\3 0 1 1 0 1 1 0

Interchanges bits 1 to 8 and bits 9 to 16 of the specified r, then loads zeros into bits 9 to 16 of r. Leaves the values of CBIT, LINK, and the condition codes unchanged.

► ICHL R

Interchange Halfwords and Clear Left 0 1 1 0 0 0 R\3 0 1 1 0 0 0 0

Interchanges the contents of bits 1 to 16 and bits 17 to 32 of the specified R, then loads zeros into bits 1 to 16 of R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ICHR R Interchange Halfwords and Clear Right 0 1 1 0 0 0 R\3 0 1 1 0 0 0 1

Interchanges the contents of bits 1 to 16 and bits 17 to 32 of the specified R, then loads zeros into bits 17 to 32 of R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

► ICP R

Increment C Pointer 0 1 1 0 0 0 R\3 1 1 1 0 1 1 1

Increments the C language pointer in the specified R by 1 byte. Incrementing the largest offset adds 1 to the segment number. Incrementing the largest segment number with the largest offset generates a pointer to segment 0, offset 0, byte 1. Leaves the CBIT, LINK, and the condition codes unchanged. (For C pointer details, see <u>I</u> <u>Mode</u> in Chapter 1 and <u>32 I Mode</u> in Appendix B of this guide.)

# Note

If ICP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

IH r, address Interchange r and Memory Halfword 1 0 1 0 0 1 DR\3 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Interchanges the value contained in the specified r with the 16-bit value contained in the location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

The IH instruction is non-atomic, and, especially for dual-stream processors, cannot be used for spin-locks. In these cases, use the STCH instruction instead.

This instruction also has a register-to-register form. See Appendix B for more information.

# IH1 r Increment r by 1 0 1 1 0 0 0 R\3 1 0 1 0 1 1 0

Increments the contents of the specified r by 1 and stores the result in r. An overflow causes an integer exception. If no integer exception occurs, CBIT is reset to 0. LINK reflects the state of the carry. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

IH2 r Increment r by 2 0 1 1 0 0 0 R\3 1 0 1 0 1 1 1

Increments the contents of the specified r by 2 and stores the result in r. An overflow causes an integer exception to occur. If no integer exception occurs, CBIT is reset to 0. LINK reflects the state of the carry. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

IM address Increment Memory Fullword 1 0 0 1 1 0 0 0 0 TM\2 SR\3 ER\2 DISPLACEMENT\16

Adds 1 to the 32-bit integer contained in the specified location and stores the result back in the specified location. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the operation. (See Appendix A.) IMH address Increment Memory Halfword 101110000TM\2SR\3BR\2 DISPLACEMENT\16

Adds 1 to the 16-bit integer contained in the specified location and stores the result back in the specified location. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the operation. (See Appendix A.)

INBC address Interrupt Notify Beginning, Clear Active Interrupt 0 0 0 0 0 0 1 0 1 0 0 0 1 1 1 1 AP\32

Notifies a semaphore at the specified address during phantom interrupt code. Restores the state of the interrupted process by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from microcode temporary registers PSWPB and PSWKEYS. Places the notified process at the beginning of the appropriate priority level queue. Issues a CAI pulse to clear the currently active interrupt, and enables interrupts.

The values of CBIT, LINK, and the condition codes are indeterminate. A process exchange will occur if the notified process is of a higher priority than the interrupted process. See Chapter 9 of the <u>System</u> Architecture Reference Guide for more information.

## Note

INBC is a restricted instruction.

This instruction is normally used to transfer from phantom interrupt code to an interrupt process. See Chapter 10 of the System Architecture Reference Guide for more information.

INEN address Interrupt Notify Beginning 0 0 0 0 0 0 1 0 1 0 0 0 1 1 0 1 AP\32

Notifies a semaphore at the specified address during phantom interrupt code. Restores the state of the interrupted process by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from microcode temporary registers PSWPB and PSWKEYS. Places the notified process at the beginning of the appropriate priority level queue, and enables interrupts. Does not issue a CAI pulse to clear the currently active interrupt.

The values of CBIT, LINK, and the condition codes are indeterminate. A process exchange will occur if the notified process is of a higher priority than the interrupted process. See Chapter 9 of the <u>System</u> Architecture Reference Guide for more information.

# Note

INEN is a restricted instruction.

This instruction is normally used to transfer from phantom interrupt code to an interrupt process. See Chapter 10 of the System Architecture Reference Guide for more information.

INEC address
 Interrupt Notify End, Clear Active Interrupt
 0 0 0 0 0 1 0 1 0 0 0 1 1 1 0
 AP\32

Notifies a semaphore at the specified address during phantom interrupt code. Restores the state of the interrupted process by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from microcode temporary registers PSWPB and PSWKEYS. Places the notified process at the end of the appropriate priority level queue. Issues a CAI pulse to clear the currently active interrupt, and enables interrupts.

The values of CBIT, LINK and the condition codes are indeterminate. A process exchange will occur if the notified process is of a higher priority than the interrupted process. See Chapter 9 of the <u>System</u> Architecture Reference Guide for more information.

## Note

INEC is a restricted instruction.

This instruction is normally used to transfer from phantom interrupt code to an interrupt process. See Chapter 10 of the System Architecture Reference Guide for more information.

INEN address
 Interrupt Notify End
 0 0 0 0 0 0 1 0 1 0 0 0 1 1 0 0
 AP\32

Notifies a semaphore at the specified address during phantom interrupt code. Restores the state of the interrupted process by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from microcode temporary registers PSWPB and PSWKEYS. Places the notified process at the end of the appropriate priority level queue, and enables interrupts. Does not issue a CAI pulse to clear the currently active interrupt.

The values of CBIT, LINK, and the condition codes are indeterminate. A process exchange will occur if the notified process is of a higher priority than the interrupted process. See Chapter 9 of the <u>System</u> Architecture Reference Guide for more information.

## Note

This is a restricted instruction.

This instruction is normally used to transfer from phantom interrupt code to an interrupt process. See Chapter 10 of the System Architecture Reference Guide for more information.

► INH

Inhibits interrupts by resetting bit 1 of the modals to 0. Inhibits interrupts until an enable interrupts instruction executes. The processor ignores any interrupt requests that are made over the I/O bus. This instruction takes effect immediately. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

This is a restricted instruction.

INHL Inhibit Interrupts (Local) 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1

This 850 instruction performs the same actions as INH does. Leaves the values of CBIT, LINK, and the condition codes unchanged.

Note

## INHL is a restricted instruction.

# INHM Inhibit Interrupts (Mutual) 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0

For the 850, a processor checks the availability of the mutual exclusion lock. If available, the processor sets this lock and inhibits interrupts. Otherwise, it waits for the lock to be released by the other processor and then sets the lock and inhibits interrupts. Leaves the values of CBIT, LINK, and the condition codes unchanged.

### Note

This is a restricted instruction.

INHP Inhibit Interrupts (Process) 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0

For the 850, a processor checks the availability of the process exchange lock. If available, the processor sets it and inhibits interrupts. Otherwise, it waits for the lock to be released by the other processor, and then sets the lock and inhibits interrupts. It also inhibits interrupts in the local processor. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

This is a restricted instruction.

INK r Input Keys 0 1 1 0 0 0 R\3 0 1 1 1 0 0 0

Loads the contents of the I mode keys into the specified r. Leaves the values of CBIT, LINK, and the condition codes unchanged. Reads the low-order 8 bits of the S register along with the high-order 8 bits of the keys register.

INT f,R Convert Floating Point to Integer 0 1 1 0 0 0 R\3 1 0 0 F 0 1 1

Converts the double precision floating-point number contained in the specified floating accumulator to a 32-bit integer and stores the result in R. Ignores the fractional part of the floating-point number. For example, +4.5 is converted to +4 and -4.5 is converted to -4.

Overflow occurs if the value in the floating accumulator is less than  $-2^{*31}$  or greater than  $(2^{*31})-1$ . An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

INIH f,r

Convert Floating Point Number to Halfword Integer 0 1 1 0 0 0 R\3 1 0 0 F 0 0 1

Converts the double precision floating-point number contained in the specified floating accumulator to an integer and stores the result in r. Ignores the fractional portion of the floating-point number. For example, +4.5 is converted to +4 and -4.5 is converted to -4. Overflow occurs if the value in the floating accumulator is less than  $-2^{**15}$  or greater than  $(2^{**15})-1$ . An overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0.

At the end of this instruction, the contents of R bits 17 to 32 are indeterminate. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 in the keys contains 1, the instruction sets CBIT to 1. If bit 7 contains 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

IR1 R Increment Register by 1 0 1 1 0 0 0 R\3 1 0 1 0 0 1 0

Increments the contents of the specified R by 1 and stores the result in R. An overflow causes an integer exception fault. If no integer exception occurs, CBIT is reset to 0. LINK contains the carry-out bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 in the keys contains 0, the IR1 instruction sets CBIT to 1. If bit 8 contains 1, the instruction sets CBIT to 1 and causes an integer exception fault. (See Chapter 10 of the System Architecture Reference Guide.) IR2 R Increment Register by 2 0 1 1 0 0 0 R\3 1 0 1 0 0 1 1

Increments the contents of the specified R by 2 and stores the result in R. An overflow causes an integer exception fault. If no integer exception occurs, CBIT is reset to 0. LINK contains the carry-out bit. The condition code contains the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 in the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains 1, the instruction sets CBIT to 1 and causes an integer exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

IRB r Interchange r Bytes 0 1 1 0 0 0 R\3 0 1 1 0 1 0 0

Interchanges bits 1 to 8 and bits 9 to 16 of the specified r. Leaves the values of CBIT, LINK, and the condition codes unchanged.

IRH R Interchange Register Halves 0 1 1 0 0 0 R\3 0 1 0 1 1 1 1

Interchanges the contents of bits 1 to 16 and bits 17 to 32 of the specified R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

IRTC Interrupt Return, Clear Active Interrupt 0 0 0 0 0 0 1 1 0 0 0 0 0 1 1

Returns from an interrupt. Restores the state existing before the interrupt by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from the values saved in microcode temporary registers PSWPB and PSWKEYS. Issues a CAI pulse to clear the currently active interrupt, and enables interrupts.

# Note

IRTN Interrupt Return 0 0 0 0 0 0 0 1 1 0 0 0 0 0 1

Returns from an interrupt. Restores the state existing before the interrupt by loading bits 1 to 16 of PB, bits 17 to 32 of the program counter, and the keys from the values saved in microcode temporary registers PSWPB and PSWKEYS, and enables interrupts. Does not issue a CAI pulse to clear the currently active interrupt.

Note

This is a restricted instruction.

ITLB Invalidate STLB Entry 000000011001101

Invalidates the STLB entry that corresponds to the virtual address contained in GR2. The values of CBIT, LINK, and the condition codes are indeterminate. You must execute this instruction whenever you change the page table entry for the given address.

If you change an SDW or DTAR (explained in Chapter 4 of the <u>System</u> <u>Architecture Reference Guide</u>), you usually have to invalidate the entire STLB by issuing the instruction PTLB. A 0 in the segment number portion of GR2 invalidates the IOTLB entry corresponding to the address specified by GR2.

Note

JMP address
 Jump
 1 0 1 1 1 0 0 0 1 TM\2 SR\3 ER\2
 DISPLACEMENT\16

Calculates an effective address, EA, and loads it into the program counter. Leaves the values of CBIT, LINK, and the condition codes unchanged.

JSR r, address Jump to Subroutine 1 1 1 0 1 1 DR\3 TM\2 SR\3 ER\2 DISPLACEMENT\16

Calculates an effective address, EA. Saves the 16-bit halfword number position of the return address in the specified r. Loads the program counter with the current segment location specified by bits 17 to 32 of the EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

This instruction is useful for calling routines within the current segment only.

JSXB address
 Jump and Save in XB
 1 0 1 1 0 0 0 1 TM\2 SR\3 BR\2
 DISPLACEMENT\16

Calculates an effective address, EA. Loads the contents of the program counter into XB. Loads EA into the program counter. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

JSXB can make subroutine calls outside the current segment as well as within.

L R, address Load Full Word 0 0 0 0 1 DR\3 TM\2 SR\3 ER\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Loads EA into the specified R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

 LOC r, address
 Load C Character
 1 0 0 1 0 1 DR\3 TM\2 SR\3 BR\2 DISPLACEMENT\16

Calculates a C language pointer and uses it to load a single character into bits 9 to 16 of the specified r. If bit 4 of the C pointer contains 0, bits 1 to 8 of the location contain the character to be loaded; if bit 4 of the pointer contains 1, bits 9 to 16 of the location contain the character.

Clears bits 1 to 8 of r, but leaves bits 17 to 32 of R unchanged. Sets the condition code EQ to 1 (indicating equal to 0) when 0 is loaded; resets EQ to 0 (indicating not equal to zero) for all other characters. The state of the LT condition code is indeterminate. Testing the results should be done using either BCEQ or BCNE branches only. Leaves the values of CBIT and LINK unchanged.

#### Note

The LOC instruction is valid only for general register relative and indirect forms of address formation. Other forms of address formation (including indexing) do not reliably generate the C language pointer.

In particular, do not use the register-to-register or immediate form with the LOC instruction because it would be interpreted as a CCP instruction. (LOC and CCP share the same opcode, but CCP uses the register-to-register form; the immediate form of CCP is undefined, but the preferred implementation is a UII (unimplemented instruction.)

Direct addressing, however, will obtain the first byte (of two) pointed to by the effective address. This assumes that the base register used was loaded with a conventional 32-bit IP with the E bit reset.

If LOC is used for any earlier system listed in "About This Book", a UII fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

LCEQ r Load Register on Condition Code EQ 0 1 1 0 0 0 R\3 1 1 0 1 0 1 1

If the condition codes reflect an equal to 0 condition, the instruction loads the specified r with a 1. If they reflect a not equal to 0 condition, the instruction loads r with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

LOGE r Load Register on Condition Code GE 0 1 1 0 0 0 R\3 1 1 0 1 1 0 0

If the condition codes reflect a greater than or equal to 0 condition, the instruction loads the specified r with a 1. If they reflect a less than 0 condition, the instruction loads r with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

LOGT r Load Register on Condition Code GT 0 1 1 0 0 0 R\3 1 1 0 1 1 0 1

If the condition codes reflect a greater than 0 condition, the instruction loads the specified r with a 1. If they reflect a less than or equal to 0 condition, the instruction loads r with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ICLE r Load Register on Condition Code LE 0 1 1 0 0 0 R\3 1 1 0 1 0 0 1

If the condition codes reflect a less than or equal to 0 condition, the instruction loads the specified r with a 1. If they reflect a greater than 0 condition, the instruction loads r with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

LCLT r Load Register on Condition Code LT 0 1 1 0 0 0 R\3 1 1 0 1 0 0 0

If the condition codes reflect a less than 0 condition, the instruction loads the specified r with a 1. If they reflect a greater than or equal to 0 condition, the instruction loads r with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

▶ LCNE r

Load Register on Condition Code NE 0 1 1 0 0 0 R\3 1 1 0 1 0 1 0

If the condition codes reflect a not equal to 0 condition, the instruction loads the specified r with a l. If they reflect an equal to 0 condition, the instruction loads r with a 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

► LDAR R, address Load Addressed Register 100100DR\3TM\2SR\3BR\2 DISPLACEMENT\16

a 32-bit (1-word) effective address, EA. Loads the Calculates specified R with the contents of the register file location specified by the offset portion of EA. Bit 2 and bit 12 of the offset portion of EA determine the actions of this instruction.

- Action Bit 2 Bit 12
  - 1\* Ignore bits 1 and 3 to 9. The offset portion of EA specifies an absolute register number from 0 to '377.
  - 0\* 1 Bits 13 to 16 of the offset portion of EA specify one of the registers '20 to '37 in the current register set.
  - 0 0 Bits 13 to 16 of the offset portion of EA specify one of the registers 0 to '17 in the current register set.

\*This is a restricted instruction.

Leaves the values of CBIT and LINK unchanged; the values of the condition codes are indeterminate. See Chapter 9 of the System Architecture Reference Guide for more information about register sets.

# Note

If the current ring is not 0 and EA is outside the range of 0 to '17, inclusive, any access causes an RXM violation.

LDC flr,r
 Load Character
 0 1 1 0 0 0 R\3 1 1 1 FLR 0 1 0

If the contents of the specified FIR are nonzero, the instruction fetches the single character pointed to by the appropriate FAR and loads it into bits 9 to 16 of r. When the FAR's bit field contains 0, it specifies the left byte (bits 1 to 8) of the 16-bit addressed quantity; when the bit field contains 8, the right byte (bits 9 to 16) is specified. This instruction loads zeros into bits 1 to 8 of r. Updates the contents of the FAR by 8 (one byte) so that they point to the next character. Decrements the contents of the specified FIR by 1. Sets the condition codes to NE. Leaves the values of CBIT and LINK unchanged.

If the contents of the specified FLR are 0, the instruction sets the condition codes to EQ.

#### Note

This instruction uses FARO when FLRO is specified, and FARI when FLRI is specified.

LEQ R Load Register on Equal to 0 0 1 1 0 0 0 R\3 0 0 0 0 0 1 1

If the contents of the specified R are equal to 0, the instruction loads r with a 1. If not equal to 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

# ▶ LF r

Logic Set False 0 1 1 0 0 0 R\3 0 0 0 1 1 1 0

Loads the specified r with 0. Leaves the values of LINK and CBIT unchanged. The values of the condition codes are indeterminate.

LFEQ f,r Load Register on Floating Accumulator Equal to 0 0 1 1 0 0 0 R\3 0 0 1 F 0 1 1

If the contents of the specified floating accumulator are equal to 0, the instruction loads the specified r with a 1; if not equal to 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LFEQ works correctly only on normalized or nearly normalized numbers, because it checks fraction bits 1 to 32 only for equal to 0 and less than 0. (See the System Architecture Reference Guide, Chapter 6.)

LFGE f,r Load Register on Floating Accumulator Greater Than or Equal to 0 0 1 1 0 0 0 R\3 0 0 1 F 1 0 0

If the contents of the specified floating accumulator are greater than or equal to 0, the instruction loads the specified r with a 1; if less than 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LFGE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the <u>System Architecture Reference</u> Guide.)

LFGT f,r

Load Register on Floating Accumulator Greater Than O  $0 1 1 0 0 0 R \setminus 3 0 0 1 F 1 0 1$ 

If the contents of the specified floating accumulator are greater than 0, the instruction loads the specified r with a 1; if less than or equal to 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LFGT works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

# LFLE f,r

Load Register on Floating Accumulator Less Than or Equal to 0 0 1 1 0 0 0 R\3 0 0 1 F 0 0 1

If the contents of the specified floating accumulator are less than or equal to 0, the instruction loads the specified r with a 1; if greater than 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LFLE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)



Loads the 16-bit, unsigned integer contained in bits 17 to 32 (the second halfword) of the instruction into the specified FIR. Clears the upper bits of the FIR. Leaves the values of CBIT, LINK, the condition codes, and the associated FAR unchanged.

LFLT f,r Load Register on Floating Accumulator Less Than 0 0 1 1 0 0 0 R\3 0 0 1 F 0 0 0

If the contents of the specified floating accumulator are less than 0, the instruction loads the specified r with a 1; if greater than or equal to 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LFLT works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

LFNE f,r Load Register on Floating Accumulator Not Equal to 0 0 1 1 0 0 0 R\3 0 0 1 F 0 1 0

If the contents of the specified floating accumulator are not equal to 0, LFNE loads the specified r with a 1; if equal to 0, LFNE loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)
LFNE works correctly only on normalized or nearly normalized numbers, because it checks the first 32 fraction bits only for equal to zero and less than zero. (See Chapter 6 in the System Architecture Reference Guide.)

LGE R Load Register on Greater Than or Equal to 0 0 1 1 0 0 0 R\3 0 0 0 0 1 0 0

If the contents of the specified R are greater than or equal to 0, the instruction loads r with a 1; if less than 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LGT R Load Register on Greater Than 0 0 1 1 0 0 0 R\3 0 0 0 0 1 0 1

If the contents of the specified R are greater than 0, the instruction loads r with a 1; if less than or equal to 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LH r, address
 Load Halfword
 0 0 1 0 0 1 DR\3 TM\2 SR\3 BR\2
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Loads the 16-bit contents contained in the location specified by EA into r. Leaves the values of CBIT, LINK, and the condition codes unchanged.

### Note

LH also has a register-to-register and an immediate form. (See Appendix B.)

LHEQ r Load r on EQ 0 1 1 0 0 0 R\3 0 0 0 1 0 1 1

If the contents of the specified r are equal to 0, the instruction loads r with a 1; if not equal to 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.) LHGE r Load r on GE 0 1 1 0 0 0 R\3 0 0 0 0 1 0 0

If the contents of the specified r are greater than or equal to 0, the instruction loads r with a 1; if less than 0, the instruction loads r with a O. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LHGT r Load r on GT 0 1 1 0 0 0 R\3 0 0 0 1 1 0 1

If the contents of the specified r are greater than 0, the instruction loads r with a l; if less than or equal to 0, the instruction loads r with a O. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LHL1 r, address Load Halfword Shifted Left by 1  $0 \ 0 \ 0 \ 1 \ 0 \ 0 \ DR \ 3 \ TM \ 2 \ SR \ 3 \ BR \ 2$ [ DISPLACEMENT  $\setminus 16$  ]

Calculates an effective address, EA. Shifts the contents of the location specified by EA left one bit and stores the result in the specified r. (Shifts zero into the vacated bit.) Leaves the values of CBIT, LINK, and the condition codes unchanged.

Note

LHL1 also has a register-to-register form. (See Appendix B.)

LHL2 r, address Load Halfword Shifted Left by 2 0 0 1 1 0 0 DR 3 TM 2 SR 3 BR 2[ DISPLACEMENT | 16 ]

Calculates an effective address, EA. Shifts the 16-bit contents of the location specified by EA left two bits and stores the result in the specified r. (Shifts zeros into the vacated bits.) Leaves the values of CBIT, LINK, and the condition codes unchanged.

### Note

LHL2 also has a register-to-register form. (See Appendix B.)

LHL3 r,address Load Halfword Shifted Left by 3 0 1 1 1 0 1 DR\3 TM\2 SR\3 ER\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Shifts the 16-bit contents of the location specified by EA left three bits and stores the result in the specified r. (Shifts zeros into the vacated bits.) Leaves the values of CBIT, LINK, and the condition codes unchanged.

### Note

LHL3 also has a register-to-register form. (See Appendix B.)

If LHL3 is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

LHLE r Load r on LE 0 1 1 0 0 0 R\3 0 0 0 1 0 0 1

If the contents of the specified r are less than or equal to 0, the instruction loads r with a 1; if greater than 0, the instruction loads r with 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LHLT r Load r on LT 0 1 1 0 0 0 R\3 0 0 0 0 0 0 0

If the contents of the specified r are less than 0, the instruction loads r with a 1; if greater than or equal to 0, loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LHNE r Load r on NE 0 1 1 0 0 0 R\3 0 0 0 1 0 1 0

If the contents of the specified r are not equal to 0, the instruction loads r with a 1; if equal to 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LIOT address
 Load IOTLB
 0 0 0 0 0 0 0 0 0 0 1 0 0 1 0 0
 AP\32

Loads a specified IOTLB entry. Table 3-4 shows the contents of the LIOT entry and the origin of the information. The values of CBIT, LINK, and the condition codes are indeterminate.

## Table 3-4 LIOT Data

| Origin                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AP in LIOT                                     | Virtual address in I/O segment (calculated)                                                                                                                                                                                                                                                                                                                                                                |
| Page table<br> <br>                            | Physical address (translation of the<br>virtual address) obtained from I/O<br>segment. If the fault bit is set<br>to 1, a page fault occurs.                                                                                                                                                                                                                                                               |
| GR2 register<br> <br> <br> <br> <br> <br> <br> | <ul> <li>Target virtual address. This is the</li> <li>segment number and page number of the</li> <li>virtual address that will be used by</li> <li>procedures accessing this information.</li> <li>This is used to help invalidate the</li> <li>proper locations in the cache. The</li> <li>segment number and the low-order 10</li> <li>bits (offset number in the page) are</li> <li>ignored.</li> </ul> |

### Note

This is a restricted instruction.

LIP R, address Load Indirect Pointer 1 1 0 1 0 1 DR\3 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Loads the value contained in the location specified by EA into the specified R. Checks these contents for a pointer fault.

This pointer fault is generated when the contents of the memory location to be loaded into the specified R contain a pointer fault (bit 1 contains 1).

If this pointer fault occurs, the pointer to the memory location is saved in FADDR (SB + 11) as well as bits 1 to 16 of the contents of that memory location FOODEH (SB + 10). After completion of the fault handling mechanism, the instruction can be re-executed. (See Chapter 10 of the System Architecture Reference Guide.)

Leaves the values of CBIT, LINK, and the condition codes unchanged.

### Note

LIP should weaken the ring field against the ring field of the effective address. This is not done on some current processors, but will be done on all future processors.

If LIP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

LLE R Load Regist

Load Register on Less Than or Equal to 0 0 1 1 0 0 0  $R \setminus 3$  0 0 0 0 0 0 1

If the contents of the specified R are less than or equal to 0, the instruction loads r with a 1. If the contents of R are greater than 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LLT R

Load Register on Less Than 0 0 1 1 0 0 0  $\mathbb{R}$  3 0 0 0 0 0 0 0

If the contents of the specified R are less than 0, the instruction loads r with a 1. If the contents of R are greater than or equal to 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LNE R Load Register on Not Equal to 0 0 1 1 0 0 0 R\3 0 0 0 0 0 1 0

If the contents of the specified R are not equal to 0, the instruction loads r with a 1; if equal to 0, the instruction loads r with a 0. Leaves the values of LINK and CBIT unchanged. The condition codes reflect the result of the comparison. (See Appendix A.)

LPID Load Process ID 0 0 0 0 0 0 0 1 1 0 0 0 1 1 1 1

Loads the process ID from bits 1 to 10 of GR2 into RPID (the process ID register, which contains the 10 most significant bits of the user's address space). Leaves the values of CBIT, LINK, and the condition codes unchanged.

The RPID data is used to update the process ID field of an STLB entry as required. This RPID data is later used during subsequent memory accesses to verify that STLB data is still valid (STLB hit) or not (STLB miss). This register is for internal machine operation, and should not normally be modified by the user.

### Note

LPID is a restricted instruction.

LPSW address
 Load PSW
 0 0 0 0 0 0 0 1 1 1 0 0 1 0 0 1
 AP\32

Changes the status of the processor by loading new values into the program counter, keys, and modals. Inhibits interrupts for one instruction.

Addresses a 64-bit (4-halfword) block at the specified location. The block has the following format.

Offset in Block

### Contents

- 1 to 2 New program counter (ring, segment, offset numbers)
  - 3 New keys
  - 4 New modals

Loads the program counter and keys of the currently running process with the contents of the first three offsets (bits 1 to 48), then loads the processor modals with the contents of the fourth offset (bits 49 to 64).

The new value of bit 15 in the keys, the in-dispatch bit, can temporarily halt execution of the current process. This bit is altered by software only during a cold or a warm start. If bit 15 is 0, the currently executing process will continue to execute, but at a location defined by the new value of the program counter. If bit 15 is 1, the processor enters the dispatcher and dispatches the ready process with the highest priority. When execution resumes for the process that was temporarily halted, execution resumes at the point defined by the value of the new program counter.

Regardless of the value of bit 15, the new value of the modals takes effect immediately, since the modals are associated with the processor, not the process.

The LPSW instruction loads the 64 bits (four halfwords) of the register set that the STIR instruction cannot correctly load. STIR does not update the separate hardware registers the processor uses to maintain duplicate information for optimization. Never use the LPSW instruction to change bits 9 to 11 of the modals. These bits specify the current user register set. This means that if you do not know the current value of these bits, you must do the following each time you want to execute an LPSW:

- 1. Inhibit interrupts.
- 2. Read the current values of modal bits 9 to 11 with an LDLR '24 instruction.
- 3. Mask the old values of the modal bits into the new information.
- 4. Load the new information into the modals with an LPSW.

For the two common uses of LPSW, you do not have to perform this sequence, since the values of modal bits 9 to 11 are predictable. When you use LPSW after a Master Clear to turn on processor exchange mode, bits 9 to 11 are 010 because the processor is always initialized to register set 2. When you use LPSW to return from a fault, check, or interrupt, simply reload the values stored by the break because these values are still correct.

You should not use LPSW to set bits 16 (the save-done bit) or 15 (the in-dispatcher bit) of the keys, unless you are merely loading status following a fault, check, or interrupt. When issuing LPSW after a Master Clear, make sure you load zeros into both of these bits.

Note

This is a restricted instruction.

LT r Logic Set True 0 1 1 0 0 0 R\3 0 0 0 1 1 1 1

Loads the specified r with 1. Leaves the values of LINK and CBIT unchanged. The values of the condition codes are indeterminate.

M R, address Multiply Fullword 1 0 0 0 1 0 DR\3 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Multiplies the 32-bit value contained in the location specified by EA by the 32-bit value contained in the specified R. Stores the 64-bit result in the specified R and R+1. The least significant bit of the result is contained in bit 32 of R+1. The 150/250, 450/550/250-II, I450-II, and 2250 processors leave the CBIT and LINK unchanged. The other 50 Series processors reset the value of the CBIT to 0 and leave the value of LINK indeterminate. For all 50 Series processors, the condition codes are unchanged. This instruction cannot cause an overflow or generate an integer exception.

### Note

R must be an even numbered register.

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

MH r, address Multiply Halfword 1 0 1 0 1 0 R\3 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Multiplies the 16-bit value contained in the location specified by EA by the 16-bit value contained in the specified r. Stores the 32-bit result in R. Bit 32 of R contains the least significant bit of the result. The value of the CBIT is reset to 0. The value of LINK is indeterminate, and the condition codes are unchanged. This instruction cannot cause an overflow or generate an integer exception.

Note

MH r also has a register-to-register and an immediate form. See Appendix B for more information. N R, address AND Fullword 0 0 0 0 1 1 DR\3 TM\2 SR\3 ER\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Logically ANDs the value contained in the specified R with the 32-bit value contained in the location specified by EA. Stores the result in the specified R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

NFYB address Notify to Beginning 0 0 0 0 0 0 1 0 1 0 0 0 1 0 0 1 AP\32

Notifies on semaphore at address specified in second and third halfwords of the instruction. Uses LIFO (last in, first out) queueing. Does not clear the currently active interrupt. The values of CBIT, LINK, and the condition codes are indeterminate. For more information, see Chapter 9 of the System Architecture Reference Guide.

Note

This is a restricted instruction.

NFYE address
 Notify to End
 0 0 0 0 0 0 1 0 1 0 0 0 1 0 0 0
 AP\32

Notifies on semaphore at the address specified in second and third halfwords of the instruction. Uses FIFO (first in, first out) queueing. Does not clear the currently active interrupt. The values of CBIT, LINK, and the condition codes are indeterminate. For more information, see Chapter 9 of the System Architecture Reference Guide.

### Note

### This is a restricted instruction.

NH r, address AND Halfword 0 0 1 0 1 1 DR\3 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Logically ANDs the value contained in the specified r with the 16-bit value contained in the location specified by EA. Stores the result in r. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

NH also has a register-to-register and an immediate form. See Appendix B for more information.

NOP

Does nothing. Leaves the values of CBIT, LINK, and the condition codes unchanged.

O R, address OR Fullword 0 1 0 0 1 1 DR\3 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Logically ORs the value contained in the specified R with the 32-bit value contained in the location specified by EA. Stores the result in the specified R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

OH r, address OR Halfword 0 1 1 0 1 1 R\3 TM\2 SR\2 ER\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Logically ORs the value contained in the specified r with the 16-bit value contained in the location specified by EA. Stores the result in r. Leaves the values of CBIT, LINK, and the condition codes unchanged.

### Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

OIK r Output Keys 0 1 1 0 0 0 R\3 0 1 1 1 0 0 1

Stores the contents of the specified r in the keys. Resets bits 15 to 16 of the keys to 0. Loads CBIT, LINK, and the condition codes from the specified r as a result of the operation. If this instruction is executed in Ring 0, it inhibits interrupts during execution of the next instruction. PCL address Procedure Call 1 0 0 1 1 0 0 0 1 TM\2 SR\3 ER\2 DISPLACEMENT\16

See Chapter 8 of the <u>System Architecture Reference Guide</u> for a complete description of this instruction. Sets CBIT, LINK, and the condition codes to the values contained in the ECB.

### Note

When arguments are to be transferred to the called procedure, this instruction uses GR5 and GR7, destroying the previous contents of these registers. XB is updated if an AP has the S bit = 0. The contents of GR5, GR7, and XB remain unchanged if no arguments are transferred. The contents of the condition codes, CBIT, and LINK are not correctly saved in the ECB along with the rest of the caller's keys.

PID R Position for Integer Divide 0 1 1 0 0 0 R\3 0 1 0 1 0 1 0

Positions a register for integer divide. Loads the contents of the specified R into R+1. Extends the sign of R (bit 1) into bits 2 to 32 of R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

### Note

R must be a even numbered register.

PIDH r Position r for Integer Divide 0 1 1 0 0 0 R\3 0 1 0 1 0 1 1

Moves the contents of the specified r (bits 1 to 16 of R) into bits 17 to 32 of R. Extends the contents of bit 1 of r into bits 2 to 16 of R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

PIM R Position After Multiply 0 1 1 0 0 0 R\3 0 1 0 1 0 0 0

Checks bit 1 of R+1 to see if it is the same as all the bits in the specified R, and then moves the contents of R+1 into R. If bit 1 of R+1 was not the same as all the bits in R, an overflow occurs which causes an integer exception. If no integer exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If an integer exception occurs and bit 8 in the keys contains 0, the PIM instruction sets CBIT to 1. If bit 8 contains 1, the instruction sets CBIT to 1 and causes an integer exception fault. For more information, see Chapter 10 of the System Architecture Reference Guide.

### Note

R must be an even numbered register.

PIMH r Position r after Multiply 0 1 1 0 0 0 R\3 0 1 0 1 0 0 1

Checks the contents of bit 17 of the specified R to see if it has the same value as do all of bits 1 to 16 of R, and then moves the contents of bits 17 to 32 into bits 1 to 16. If bit 17 was different from all of bits 1 to 16, an integer exception occurs. If no integer exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

### Note

To position bits 17 to 32 of R in bits 1 to 16 of R, PIMH can modify all 32 bits of R, meaning that the contents of bits 17 to 32 of R are indeterminate at the end of this instruction. PRTN Procedure Return 0 0 0 0 0 0 0 1 1 0 0 0 1 0 0 1

Deallocates the stack frame created for the executing procedure and returns to the environment of the procedure that called it.

To deallocate the frame, the instruction stores the current value of the stack base register into the free pointer. It then restores the caller's state by loading the caller's program counter, stack base register, linkage base register, and keys with the values contained in the frame being deallocated. Sets bits 15 to 16 of the keys to 0.

Loads the ring number in the program counter with the logical OR (weaker) of the saved program counter ring and the current ring number. This process prevents inward returns but also allows returns from gated calls to work properly.

PTLB

Purge TLB 0 0 0 0 0 0 0 0 0 0 1 1 0 1 0 0

GR2 contains the address of a physical page, right justified. Based on the value of GR2 bit 1, PTLB purges either the first 128 locations of the STLB (i.e., not the IOTLB), or a specified physical page. If GR2 bit 1 contains a 1, the instruction performs a complete purge. If GR2 bit 1 contains a 0, the instruction purges the page specified by GR2. Leaves the values of CBIT, LINK, and the condition codes indeterminate. See Chapters 1, 4, and 11 of the <u>System Architecture Reference Guide</u> for more information about the STLB and IOTLB.

### Note

This is a restricted instruction.

On the 750, 850, 2350 to 9955 II, insert a CRE (Clear E) instruction before PTLB. Since PTLB uses E (GR3 in I mode) as a pointer, the CRE zeros GR3 before PTLB manipulates it. If an interrupt occurs during PTLB's execution, GR3 points to the location PTLB is currently purging. PTLB leaves the contents of GR3 in an undefined state at the end of its execution.

QFAD address Quad Precision Floating Add 0 1 1 1 1 0 1 1 0 TM\2 SR\3 BR\2 DISPLACEMENT\16

Calculates an effective address, EA. Adds the 112-bit, quad precision number contained in the locations specified by EA to the contents of QAC. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Normalizes the result, if necessary, and loads it into QAC. An overflow or underflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide.

### Note

If QFAD is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFC address Quad Precision Floating Compare 1 0 0 1 1 0 1 1 1 TM\2 SR\3 BR\2 DISPLACEMENT\16

Calculates an effective address, EA. Compares the contents of QAC (explained in Chapter 6 of the <u>System Architecture Reference Guide</u>) to the 112-bit contents of the location specified by EA. Leaves the values of CBIT and LINK unchanged. Sets the condition codes (OC) to the outcome of the comparison as shown below.

# Condition

 $\infty$ 

Contents of QAC > contents of location specified by EA. GT

Contents of QAC = contents of location specified by EA. EQ

Contents of QAC < contents of location specified by EA. LT

On some processors, QFC works correctly only on normalized numbers as follows. The comparison has a maximum of three sequential stages: first the signs, then the exponents, and finally the fractions of the two numbers are compared for equality. If the comparison during any one of these stages reveals an inequality, the results are returned and the instruction ends. Unnormalized numbers are unexpected and produce unexpected results. Other processors actually perform a subtract, resulting in a proper comparison.

If QFC is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

## ► QFCM

Quad Precision Floating Complement 1 1 0 0 0 0 0 1 0 1 1 1 1 0 0 0

Forms the two's complement of the value contained in QAC. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Normalizes the result, if necessary, and stores it in QAC. An underflow or overflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide.

### Note

If QFCM is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)



QFDV address
 Quad Precision Floating Point Divide
 1 0 0 1 1 0 1 1 0 TM\2 SR\3 BR\2
 DISPLACEMENT\16

Calculates an effective address, EA. Divides the contents of QAC by the 112-bit contents of the location specified by EA. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Normalizes the result, if necessary, and stores the whole quotient into QAC. An overflow, underflow, or divide by to causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide.

If QFDV is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFLD address Quad Precision Floating Load 0 1 1 1 1 0 1 0 0 TM\2 SR\3 BR\2 DISPLACEMENT\16

Calculates an extended, augmented effective address, EA. Performs one of the following actions with the value contained in the location specified by EA. Loads bits 1 to 112 into QAC and zeros QAC bits 113 to 128, or loads 128 bits into QAC. In either case, there is no normalization of the result. (See Chapter 6 of the <u>System Architecture</u> <u>Reference Guide</u> for more information.) Leaves the values of CBIT, LINK, and the condition codes unchanged.

### Note

If QFLD is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFMP address
 Quad Precision Floating Point Multiply
 1 0 0 1 1 0 1 0 1 TM\2 SR\3 BR\2
 DISPLACEMENT\16

Calculates an effective address, EA. Multiplies the contents of QAC by the 112-bit contents of the location specified by EA. (See Chapter 6 of the System Architecture Reference Guide.) Normalizes the result, if necessary, and stores it into QAC. An overflow or underflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information.

If QFMP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFSB address
 Quad Precision Floating Point Subtract
 0 1 1 1 1 0 1 1 1 TM\2 SR\3 BR\2
 DISPLACEMENT\16

Calculates an effective address, EA. Subtracts the 112-bit contents of the locations specified by EA from the contents of QAC. (See Chapter 6 of the <u>System Architecture Reference Guide</u>.) Normalizes the result, if necessary, and loads it into QAC. An overflow or underflow causes a floating-point exception. If no floating-point exception occurs, CBIT is reset to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

### Note

If QFSB is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QFST address
 Quad Precision Floating Store
 0 1 1 1 1 0 1 0 1 TM\2 SR\3 ER\2
 DISPLACEMENT\16

Calculates an effective address, EA. Stores the contents of QAC into the 128 bits of memory specified by EA. Leaves the values of LINK, CBIT, and the condition codes unchanged.

### Note

QFST does not normalize the result before storing it into the specified memory location.

If QFST is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

Second Edition

## QINQ Quad to Integer, in Quad Convert 1 1 0 0 0 0 0 1 0 1 1 1 0 1 0

Strips the fractional portion of QAC as described in Table 3-5.

| Exponent Value    | Action                                                                                                                                                                                                                                                 |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| '337 <= Exp       | No operation.                                                                                                                                                                                                                                          |
| '200 < Exp < '337 | <pre>If sign &gt;= 0, strip fractional part of QAC for result. If sign &lt; 0 and fractional part &lt;&gt; 0, strip fractional part of QAC and increment integer portion of QAC by 1. If sign &lt; 0 and fractional part = 0, no action is done.</pre> |
| '200 = Exp        | <pre>If sign &gt;= 0, result = 0. If sign &lt; 0 and bits 2 to 96 = 0 result = -1. If sign &lt; 0 and bits 2 to 96 &lt;&gt; 0 result = 0.</pre>                                                                                                        |
| '200 > Exp        | Result = 0.                                                                                                                                                                                                                                            |

Table 3-5 QINQ Actions

QINQ can cause a floating-point exception. This exception does not alter the contents of QAC. If no exception occurs, the instruction resets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

Note

If QINQ is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

QIQR Quad to Integer, in Quad Convert Rounded 1 1 0 0 0 0 0 1 0 1 1 1 1 0 1 1

Strips the fractional portion of QAC as described in Table 3-6.

| Exponent Value                  | I              | Action                                                                                                                                                                                                                                                    | 1          |
|---------------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
|                                 |                | No operation.                                                                                                                                                                                                                                             | 1<br> <br> |
| '177 < Exp < '337<br> <br> <br> | <br> <br> <br> | If sign >= 0, round.*<br>If sign < 0 and fractional part <> 0.5,**<br>round and strip the fractional part<br>of QAC.                                                                                                                                      |            |
| Exp = '177                      |                | <pre>If sign &gt;= 0, result = 0. If sign &lt; 0 and bits 2 to 96 = 0, result = -1. If sign &lt; 0 and bits 2 to 96 &lt;&gt; 0, result = 0. For all cases increment integer part by 1 if     it exists and the most significant bit of     QAC = 1.</pre> |            |
| I Exp < '177                    | ļ              | The result is 0.                                                                                                                                                                                                                                          | 1          |

Table 3-6 QIQR Actions

\* Rounding occurs if the MSB of the QAC fraction is 1. For example, add the MSB of the QAC fraction to itself and carry out to the QAC integer.

\*\* 0.5 implies a QAC fraction with the MSB = 1 and all other bits = 0.

QIQR can cause a floating-point exception. This exception does not alter the contents of QAC. If no exception occurs, the instruction sets CBIT to 0. The values of LINK and the condition codes are indeterminate.

If a floating-point exception occurs and bit 7 of the keys contains a 1, the QIQR instruction sets CBIT to 1. If bit 7 contains a 0, the instruction sets CBIT to 1 and causes a floating-point exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

r

If QIQR is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the <u>System Architecture Reference Guide</u>.) RBQ r,address Remove Entry From Bottom of Queue 0 1 1 0 0 0 R\3 1 0 1 1 0 1 1 AP\32

The address pointer in this instruction points to the QCB for a queue. The instruction removes the entry from the bottom of the referenced queue and loads it into the specified r. If the queue was not empty, this instruction sets the condition codes to reflect not equal to. If the queue was empty, resets r to 0 and sets the condition codes to reflect equal to. Leaves the values of CBIT and LINK unchanged.

RCB Reset CBIT to 0 1 1 0 0 0 0 0 1 0 0 0 0 0 0

Resets CBIT to 0. Leaves the values of LINK and the condition codes unchanged.

RMC Reset Machine Check Flag to 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 1

Resets the machine check mode (bits 15 to 16 of the modals) to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged. Inhibits interrupts for the next instruction.

Note

This is a restricted instruction.

ROT R, address Rotating Shift 0 1 0 1 0 0 DR\3 TM\2 SR\3 ER\2 DISPLACEMENT\16

Calculates an effective address, EA. Interprets bits 17 to 32 of EA as a shift command, as shown in Table 3-7.

| I Bits                 | '              | Value  |                | Interpretation                                                                                                                                                          |
|------------------------|----------------|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <br>  17<br>           | <br> <br> <br> | 0<br>1 | <br> <br> <br> | Shift left.                                                                                                                                                             |
| 18<br>1                | <br> <br>      | 0<br>1 |                | Word shift (32 bits).<br>Halfword shift (16 bits).                                                                                                                      |
| 19 to 26               | 1              |        | 1              | Ignored.                                                                                                                                                                |
| 27 to 32<br> <br> <br> | <br> <br>      |        | <br> <br>      | Values specify the two's complement of the<br>number of bits to shift. A value of 0<br>indicates a shift of 64 places; of -1,<br>1 place; of -63, 63 places; and so on. |

Table 3-7 EA Format for ROT Shift Command

Uses EA to perform a rotating shift on the contents of the specified R. Stores the shifted result in R. CBIT and LINK contain the value of the last bit shifted out. Leaves the values of the condition codes unchanged.

RRST address
 Restore Registers
 0 0 0 0 0 0 0 1 1 1 0 0 1 1 1 1
 AP\32

Calculates an effective address, EA, from the 32-bit address pointer in the instruction. This specifies the starting address of a save area for the general, floating, and XB registers. Restores the contents of these registers from this save area.

The save area format is shown in Table 3-8. Bits 1 to 16 of the save area are a save mask, whose format appears in Figure 3-3. A mask bit value of 1 means that the corresponding register had nonzero contents that have been saved in the save area; a mask bit value of 0 means that the corresponding register's contents were 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

| Offset # | Contents     |
|----------|--------------|
| 1        | Save mask    |
| 2 to 5   | FR1 (F)      |
| 6 to 9   | I FRO        |
| 10 to 11 | I X, GR7     |
| 12 to 13 | I GR6        |
| 14 to 15 | ∣Y, S, GR5   |
| 15 to 17 | GR4          |
| 18 to 19 | I E, GR3     |
| 20 to 21 | A, B, L, GR2 |
| 22 to 23 | GR1          |
| 24 to 25 | GRO          |
| 26 to 27 | I XB         |

Table 3-8 RRST and RSAV Save Area Format

| 1 ·  | 4  | 5   | 67  | 8  | 9  | 10  | ) 11 | 12  | 2 13 | 5 14 | 15  | 5 16 | 3 |
|------|----|-----|-----|----|----|-----|------|-----|------|------|-----|------|---|
| 0000 | ۱F | 'R1 | FRO | ١Œ | 27 | GR6 | IGR5 | GR4 | GR3  | GR2  | GR1 | IGRO |   |

## Save Mask Format, RRST and RSAV Instructions Figure 3-3

RSAV address
 Save Registers
 0 0 0 0 0 0 0 1 1 1 0 0 1 1 0 1
 AP\32

Calculates an effective address, EA, from the 32-bit address pointer in the instruction. This specifies the starting address of a save area for the general, floating, and XB registers. Saves the nonzero contents of these registers in the save area.

The save area format is shown in Table 3-8. Bits 1 to 16 of the save area are a save mask, whose format appears in Figure 3-3. This instruction sets the mask bit of each register as follows: to 1 if the register's contents have a nonzero value; to 0 if a 0 value. Leaves the values of CBIT, LINK, and the condition codes unchanged.

RTQ r, address Remove Entry From Top of Queue 0 1 1 0 0 0 R\3 1 0 1 1 0 1 0 AP\32

The address pointer in this instruction is to the QCB for a queue. The instruction removes the entry from the top of the referenced queue, and loads it into the specified r. If the queue was not empty, the instruction sets the condition codes to reflect not equal to 0. If the queue was empty, resets r to 0 and sets the condition codes to reflect equal to . Leaves the values of CBIT and LINK unchanged.

RTS Reset Time Slice 0 0 0 0 0 0 0 1 0 1 0 0 1 0 0 1

Valid for the 550-II, 750, 850, I450, and new processors.

GR2H (bits 1 to 16) contain a negative value that represents the number of milliseconds in the new time slice. The time slice is determined by counting ITH up every 1.024 milliseconds until zero when the time slice ends. Therefore, ITH is the two's complement of the number of milliseconds remaining in the time slice. The elapsed timer contains the total number of 1.024 millisecond units that have elapsed since process creation plus the full count of the current time slice. Combining ITH and ET by addition gives the total elapsed time.

RTS adds the current value of the interval timer (locations 16 to 17 of the PCB) to the contents of the elapsed timer (locations 10 to 11 of the PCB), then subtracts the contents of GR2H from the sum of the timers. Stores the result in the elapsed timer. Loads the contents of GR2H into the interval timer. Leaves the contents of GR2H unchanged. The values of CBIT, LINK, and the condition codes are unchanged. The addition performed by this instruction is equivalent to the following series of instructions:

| LH            | O,ITH | /* | Load GRO with contents of ITH.                 |
|---------------|-------|----|------------------------------------------------|
| SH            | 0,2   | /* | Subtract reset value in GR2H from GRO contents |
| PIDH          | 0     | /* | Sign extend the contents of GROH into bits     |
|               |       | /* | 17 to 32 of GRO.                               |
| SRC           |       | /* | Skip next 16-bit halfword if CBIT is 0.        |
| CMH           | 0     | /* | Complement GRO.                                |
| Α             | O,ET  | /* | Add ITH and ET.                                |
| $\mathbf{ST}$ | O,ET  | /* | Store result in ET.                            |
| STH           | 2,ITH | /* | Store GR2 contents in ITH.                     |

#### Note

RTS is a restricted instruction.

S R, address
 Subtract Fullword
 0 1 0 0 1 0 DR\3 TM\2 SR\3 BR\2
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Subtracts the 32-bit value contained in the location specified by EA from the value contained in the specified R. Stores the result in the specified R. If overflow occurs, an integer exception results. If no integer exception occurs, CBIT is reset to 0. LINK contains the borrow bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

## Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

SCB Set CBIT to 1 1 1 0 0 0 0 0 1 1 0 0 0 0 0 0

Sets the value of CBIT to 1. The value of LINK is indeterminate. Leaves the values of the condition codes unchanged.

SCC r, address Store C Character 1 0 1 1 0 1 DR\3 TM\2 SR\3 ER\2 DISPLACEMENT\16

Uses the C language pointer to store a single character from bits 9 to 16 of the specified r into a location in memory. (Bits 1 to 8 of r are not modified and do not affect this operation.) When bit 4 of the C pointer contains 0, the character is stored into bits 1 to 8 of the address; if bit 4 of the pointer contains 1, the character is stored into bits 9 to 16 of the address. Leaves the values of the CBIT, LINK, and condition codes unchanged.

## Note

The SOC instruction is valid only for general register relative and indirect forms of address formation. Other forms of address formation (including indexing) do not reliably generate the C language pointer. In particular, do not use the immediate or register-to-register form with the SOC instruction because it would be interpreted as an ACP instruction. (SOC and ACP share the same opcode, but ACP uses the immediate and register-to-register form.) However, direct addressing will obtain the first byte (of two) pointed to by the effective address. This assumes that the base register used was loaded with a conventional 32-bit IP with the E bit reset.

If SOC is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

SH r, address
 Subtract Halfword
 0 1 1 0 1 0 DR\3 TM\2 SR\3 ER\2
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Subtracts the 16-bit value contained in the location specified by EA from the value contained in the specified r and stores the result in r. An overflow causes an integer exception. If no integer exception occurs, CBIT is reset to 0. LINK contains the borrow bit. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

Note

The SH instruction also has a register-to-register and an immediate form. See Appendix B for more information.

SHA R, address
 Arithmetic Shift
 0 0 1 1 0 1 DR\3 TM\2 SR\3 ER\2
 DISPLACEMENT\16

Calculates an effective address, EA. Interprets bits 17 to 32 of EA as a shift command, as shown in Table 3-9.

|                | Bits            | I              | Value  |           | Interpretation                                                                                                                                                             |                |
|----------------|-----------------|----------------|--------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
|                | 17              |                | 0<br>1 |           | Shift left.<br>Shift right.                                                                                                                                                | <br> <br> <br> |
| <br> <br> <br> | 18              |                | 0<br>1 | <br> <br> | Word shift (32 bits).<br>Halfword shift (16 bits).                                                                                                                         | <br> <br>      |
| 1              | 19 to <b>26</b> |                |        |           | Ignored.                                                                                                                                                                   | ;<br>;<br>;    |
| <br> <br> <br> | 27 to 32        | <br> <br> <br> |        |           | Values specify the two's complement of<br>the number of bits to shift. A value<br>of 0 indicates a shift of 64 places;<br>of -1, 1 place; of -63, 63 places;<br>and so on. | <br> <br> <br> |

Table 3-9 EA Format for SHA Shift Command

Uses EA to perform an arithmetic shift on the contents of the specified R, and stores the result of the shift in R.

For a right shift, CBIT and LINK contain the value of the last bit shifted out. The values of all other shifted-out bits are lost.

For a left shift, an overflow causes an integer exception. If there is no integer exception, CBIT is reset to 0. The value of LINK is indeterminate.

All shifts leave the values of the condition codes unchanged.

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

SHL R, address
 Logical Shift
 0 0 0 1 0 1 DR\3 TM\2 SR\3 ER\2
 DISPLACEMENT\16

Calculates an effective address, EA. Interprets bits 17 to 32 of EA as a shift command, as shown in Table 3-10.

| _         |          |           |        |                |                                                                                                                                                                            |                   |
|-----------|----------|-----------|--------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| 1         | Bits     | I         | Value  | I              | Interpretation                                                                                                                                                             | 1                 |
|           | 17       | <br> <br> | 0<br>1 | <br> <br>      | Shift left.<br>Shift right.                                                                                                                                                | - 1<br> <br> <br> |
| <br> <br> | 18       | <br> <br> | 0<br>1 | <br> <br>      | Word shift (32 bits).<br>Halfword shift (16 bits).                                                                                                                         | <br> <br>         |
| 1         | 19 to 26 | 1         |        | <br>           | Ignored.                                                                                                                                                                   | i<br>I            |
|           | 27 to 32 | 1         |        | <br> <br> <br> | Values specify the two's complement of<br>the number of bits to shift. A value<br>of 0 indicates a shift of 64 places;<br>of -1, 1 place; of -63, 63 places;<br>and so on. |                   |

Table 3-10 EA Format for SHL Shift Command

Uses EA to perform a logical shift on the contents of the specified R. Stores the shifted result in R. CBIT and LINK contain the value of the last bit shifted out. The values of all other shifted-out bits are lost. Leaves the values of the condition codes unchanged.

SHL1 r Shift r Left 1 0 1 1 0 0 0 R\3 0 1 1 1 1 1 0

Shifts the contents of the specified r to the left one bit and stores the result in r. CBIT and LINK contain the value of the bit shifted out. Leaves the values of the condition codes unchanged.

SHL2 r Shift r Left 2 0 1 1 0 0 0 R\3 0 1 1 1 1 1 1

Shifts the contents of the specified r to the left two bits and stores the result in r. CBIT and LINK contain the value of the last bit shifted out. The value of the first bit shifted out is lost. Leaves the values of the condition codes unchanged. SHR1 r Shift r Right 1 0 1 1 0 0 0 R\3 1 0 1 0 0 0 0

Shifts the contents of the specified r to the right one bit and stores the result in r. CBIT and LINK contain the value of the bit shifted out. Leaves the values of the condition codes unchanged.

SHR2 r Shift r Right 2 0 1 1 0 0 0 R\3 1 0 1 0 0 0 1

Shifts the contents of the specified r to the right two bits and stores the result in r. CBIT and LINK contain the value of the last bit shifted out. The value of the first bit shifted out is lost. Leaves the values of the condition codes unchanged.

SL1 R Shift Register Left 1 0 1 1 0 0 0 R\3 0 1 1 1 0 1 0

Shifts the contents of the specified R to the left one bit and stores the result in R. CBIT and LINK contain the value of the bit shifted out. Leaves the values of the condition codes unchanged.

SL2 R Shift Register Left 2 0 1 1 0 0 0 R\3 0 1 1 1 0 1 1

Shifts the contents of the specified R to the left two bits and stores the result in R. CBIT and LINK contain the value of the last bit shifted out; the value of the first bit shifted out is lost. Leaves the values of the condition codes unchanged.

SR1 R Shift Register Right 1 0 1 1 0 0 0 R\3 0 1 1 1 1 0 0

Shifts the contents of the specified R to the right one bit and stores the result in R. CBIT and LINK contain the value of the bit shifted out. Leaves the values of the condition codes unchanged. SR2 R Shift Register Right 2 0 1 1 0 0 0 R\3 0 1 1 1 1 0 1

Shifts the contents of the specified R to the right two bits and stores the result in R. CBIT and LINK contain the value of the last bit shifted out; the value of the first bit shifted out is lost. Leaves the values of the condition codes unchanged.

SSM R Set Sign Minus 0 1 1 0 0 0 R\3 0 1 0 0 0 1 0

Sets bit 1 of the specified R to 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

SSP R
 Set Sign Plus
 0 1 1 0 0 0 R\3 0 1 0 0 0 1 1

Resets bit 1 of the specified R to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

SSSN Store System Serial Number 010000011001000

This instruction is applicable only for the 2350 to the 9955 II. A 14-character system identifier programmed into these processors during manufacturing consists of a 2-character plant location code followed by a 12-digit number. (These characters and numbers are in 7-bit ASCII format.) SSSN writes this system identifier into a 16-halfword block at the address specified by the XB register. (A halfword is 16 bits.) The first 8 halfwords of this block hold the system serial number string as provided by manufacturing; the remaining halfwords are reserved for future expansion and are 0.

Leaves the values of CBIT, LINK, and the condition codes indeterminate.

## Note

If SSSN is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

ST R, address Store Fullword 0 1 0 0 0 1 DR\3 TM\2 SR\3 BR\2 DISPLACEMENT\16

Calculates an effective address, EA. Stores the contents of the specified R into the location specified by EA. Leaves the values of the CBIT, LINK, and condition codes unchanged.

STAR R, address Store Addressed Register 1 0 1 1 0 0 DR\3 TM\2 SR\3 ER\2 DISPLACEMENT\16

Calculates a 32-bit (word) effective address, EA. Stores the contents of the specified R into the register location specified by the offset portion of EA. Bit 2 and bit 12 of the offset portion of EA determine the actions of this instruction, as shown in Table 3-11.

### Table 3-11 STAR Actions

|  | Bit 2 | I B            | it | 12 | I | Action                                                                                                               |
|--|-------|----------------|----|----|---|----------------------------------------------------------------------------------------------------------------------|
|  | 1*    |                |    |    |   | Ignore bits 1 and 3 to 9. The offset portion of EA specifies an absolute register number from 0 to '377.             |
|  | 0*    | <br> <br> <br> | 1  |    |   | Bits 13 to 16 of the offset portion of EA<br>specify one of the registers '20 to '37 in<br>the current register set. |
|  | 0     | <br> <br>      | 0  |    |   | Bits 13 to 16 of the offset portion of EA<br>specify one of the registers 0 to '17 in<br>the current register set.   |

\*This is a restricted instruction.

Leaves the values of CBIT and LINK unchanged. The values of the condition codes are indeterminate. See Chapter 9 of the <u>System</u> Architecture Reference Guide for more information about register sets.

Do not use the STAR instruction to write into the procedure base, keys, or modals. You can use LPSW to change any of these three registers. In addition, you can use a control transfer to change the procedure base, or a mode control operation to change the keys or modals. Under no circumstances should you try to change the value of the current register set bits contained in the modals.

If the current ring is not 0 and EA is outside the range of 0 to '17 inclusive, any access causes an RXM violation.

STC flr,r Store Character 0 1 1 0 0 0 R\3 1 1 1 FLR 1 1 0

If the contents of the specified FIR are nonzero, the instruction stores the contents of bits 9 to 16 of the specified r into the character byte address contained in the associated FAR. Updates the contents of the appropriate FAR so that they point to the next character. Decrements the contents of the specified FIR by 1. Sets the condition codes to NE.

If the contents of the specified FLR are 0, the instruction sets the condition codes to EQ and does not store a character.

The instruction leaves the values of LINK and CBIT unchanged.

Note

When the instruction specifies FLRO, FARO is used. When the instruction specifies FLR1, FAR1 is used.

STCD R, address Store Conditional Fullword 0 1 1 0 0 0 R\3 1 0 1 1 1 1 AP\32

Compares the contents of R+1 and the contents of the 32-bit location referenced by the specified address pointer. If the two values are equal, the instruction stores the contents of R in that referenced location. If the two values are not equal, execution continues with the next instruction. STCD is an interlocked operation, guaranteed to work in a multiprocessor.

Leaves the values of CBIT and LINK unchanged. The condition codes indicate reflect the result of the comparison. (See Appendix A.)

R must be an even numbered register.

STCH r, address
 Store Conditional Halfword
 0 1 1 0 0 0 R\3 1 0 1 1 1 1 0
 AP\32

Compares the contents of bits 17 to 32 of the specified R with the contents of the location referenced by the specified address pointer. If the two values are equal, the instruction stores the contents of r into that referenced location. If the two values are not equal, execution continues with the next instruction. Leaves the values of CBIT and LINK unchanged. Sets the condition codes to EQ if the store occurs and to NE if not.

The comparison and store will not be separated by execution of other instructions. Therefore, no instruction can alter the contents of the specified memory location between the compare and the store.

### Note

This instruction is useful when two cooperating, sequential processes are manipulating shared data. It is interlocked against direct memory I/O. This means you can use it to interlock a process with a DMA, DMC, or DMQ channel, as well as to interlock a memory location that is possibly accessed by I/O.

STEX R
 Stack Extend
 0 1 1 0 0 0 R\3 0 0 1 0 1 1 1

Extends the length of the procedure stack. The designated R contains a 32-bit number that specifies the halfword size of the extension. (A halfword is 16 bits.)

The firmware rounds up the number contained in the specified R to an even number of halfwords. The instruction uses this value to allocate a block of memory to the procedure stack. The extension and the initial stack segment do not have to be contiguous, since there may not have been enough room left in the initial stack to contain a complete frame.

Returns a segment number/offset number in the specified R that specifies the starting address of the extension. The extension is automatically deallocated when the current procedure completes execution. There is no limit on the number of extensions you can make. A stack fault occurs if there is no room for the extension. The values of CBIT, LINK, and the condition codes are indeterminate. See Chapters 8 and 10 of the <u>System Architecture Reference Guide</u> for more information about this instruction, stacks, and stack faults.

STFA far, address
 Store FAR
 0 0 0 0 0 0 1 0 1 1 0 1 FAR 0 0 0
 AP\32

Stores the specified FAR contents as a hardware recognizable indirect pointer at the memory location referenced by the specified address pointer. If the bit number field of the specified FAR contains 0, the instruction stores the first 32 bits (two halfwords) of the pointer and clears the pointer's extend bit to 0. If the bit number field of the specified FAR does not contain 0, the instruction saves all 48 bits (three halfwords) of the pointer and sets the pointer's extend bit to 1. Leaves the values of CBIT, LINK, and the condition codes indeterminate.

STH r, address Store Halfword 0 1 1 0 0 1 DR\3 TM\2 SR\3 ER\2 DISPLACEMENT\16

Calculates an effective address, EA. Stores the contents of the specified r into the 16-bit location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

STPM Store Processor Model Number 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0

Stores the CPU model number and microcode revision number in an 8-halfword field. (A halfword is 16 bits.) XB contains a pointer to the field in memory. Table 3-12 shows the format of the field.

| Halfword                                                               | Name                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 to 2<br> <br> | Processor<br>Model<br>Number | Contains a code specifying the machine:         OL - 400/500, no       15L - 9950         Rev B microcode       16L - 9650         1L - 400, Rev. B       17L - 2550         microcode       18L - 9955         2L - Reserved       19L - 9750         3L - 350       21L - 2350         4L - 450/550       22L - 2655         5L - 750       23L - 9655         6L - 650       25L - 2450         7L - 250       30L - 9955 II         8L - 850       31L - 2755         9L - 250-II       34L - 6350         10L - 550-II       42L - 9755         11L - 2250       11L - 2250 |
| 3 to 4                                                                 | Microcode<br>Revision        | Offset 3:<br>Bits 1 to 8 Reserved<br>Bits 9 to 16 Manufacturing microcode<br>revision number<br>Offset 4:<br>Bits 1 to 16 Engineering microcode<br>revision number                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5<br> <br> <br>                                                        | Processor<br>Line            | Specifies options enabled for this machine:<br>Bits 1 to 15 Reserved; must be 0<br>Bit 16 Marketing segment<br>specification bit                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6<br> <br>                                                             | Extended<br>Microcode        | To be implemented.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7 to 8                                                                 |                              | Reserved for future use.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Table 3-12 STPM Memory Field Format

The STPM instruction leaves the values of CBIT, LINK, and the condition codes unchanged.

## Note

### STPM is a restricted instruction.
STTM Store Process Timer 0 0 0 0 0 0 0 1 0 1 0 0 1 0 0 0

Valid for the 550-II, 850, I450, and 2350 to 9955 II.

The current process time is represented by the sum of the 32-bit elapsed time (stored in the PCB) and the 32-bit interval timer (contained in the CPU hardware). Bit 17 of the elapsed time is equivalent in weight to bit 1 of the interval time. This operation is equivalent to the following sequence of instructions. (Register O is not actually modified by the STTM instruction.)

| LDAR | O, PB% + '25 / | /* | Get PCB address.              |
|------|----------------|----|-------------------------------|
| A    | 0, = '10L /    | /* | Offset of elapsed time.       |
| ST   | 0, TEMP1 /     | /* | Elapsed time address -> Temp. |
| LDAR | 0, PB% + '30 / | /* | Read timer.                   |
| IRH  | 0 /            | /* | Store low order               |
| STH  | 0, XB% + 2     | /* | 16 bits.                      |
| IRH  | 0 /            | /* | Adjust                        |
| PIDH | 0 /            | /* | weighting.                    |
| A    | 0, TEMP1, * /  | /* | Add elapsed time.             |
| ST   | 0, XB% + 0     |    | -                             |

Leaves the values of the CBIT, LINK, and condition codes indeterminate. This instruction is not implemented on the 2250.

SVC Supervisor Call 0 0 0 0 0 0 0 1 0 1 0 0 0 1 0 1

Supervisor call. Generates a directed fault. Leaves the values of CBIT, LINK, and the condition codes unchanged.

This instruction allows you to make an operating system request that is addressing mode independent. By software convention, this instruction sends an operation code and pointers to the operating system to generate a fault. For more information, refer to Chapter 10 of the System Architecture Reference Guide. TC R Two's Complement Register 0 1 1 0 0 0 R\3 0 1 0 0 1 1 0

Forms the two's complement of the contents of the specified R and stores the result in R. An overflow causes an integer exception. If there is no integer exception, CBIT is reset to 0. The value of LINK is indeterminate. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

TCH r

Two's Complement r 0 1 1 0 0 0 R 3 0 1 0 0 1 1 1

Forms the two's complement of the contents of the specified r and stores the result in r. An overflow causes an integer exception. If there is no integer exception, CBIT is reset to 0. The value of LINK is indeterminate. The condition codes reflect the result of the operation. (See Appendix A.)

If an integer exception occurs and bit 8 of the keys contains 0, the instruction sets CBIT to 1. If bit 8 contains a 1, the instruction sets CBIT to 1 and causes an integer exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

TCNP address Test C Null Pointer 1 1 1 1 1 0 1 1 0 TM\2 SR\3 ER\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Tests bits 4 to 32 of the C language pointer in the location specified by EA for zero. When these bits are zero, this instruction sets the condition codes equal to zero; otherwise the condition codes are set not equal to zero. The values of the CBIT and LINK are unchanged.

### Note

The TCNP instruction also has a register addressing form. The syntax and format for this form of TCNP is:

TCNP R 0 1 1 0 0 0 R\3 1 1 1 1 0 0 0

Second Edition

(The expected form for TCNP register addressing would be

11111011000 SR\300

but this is, in fact, unimplemented.)

If TCNP is used for any earlier system listed in "About This Book", an unimplemented instruction (UII) fault occurs. (See Chapter 10 of the System Architecture Reference Guide.)

TFIR flr,R Transfer FIR to Register 0 1 1 0 0 0 R\3 1 1 1 FIR 0 1 1

Transfers the contents of the specified FLR into the specified R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

TM address
 Test Memory Fullword
 1 0 0 1 1 0 1 0 0 TM\2 SR\3 ER\2
 DISPLACEMENT\16

Calculates an effective address, EA. Sets the condition codes according to the numerical value of the 32-bit contents of the location specified by EA. (See Appendix A.) Leaves the values of LINK and CBIT unchanged.

TMH address Test Memory Halfword 101110100TM\2SR\3ER\2 DISPLACEMENT\16

Calculates an effective address, EA. Sets the condition codes according to the numerical value of the contents of bits 1 to 16 of the location specified by EA. (See Appendix A.) Leaves the values of LINK and CBIT unchanged.

TRFL flr,R Transfer Register to FLR 0 1 1 0 0 0 R\3 1 1 1 FLR 1 0 1

Transfers the contents of R into the specified FIR. Clears bits 1 to 11 of R to 0 so that bits 1 to 6 of the specified FIR will be 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

The TRFL instruction allows you to load the specified FLR with a value computed at execution time. The maximum allowable integer you can load is 2\*\*20. This number is 21 bits wide and equals the number of bits in a 64K segment.

TSTQ r, address
 Test Queue
 0 1 1 0 0 0 R\3 1 0 0 0 1 0 0
 AP\32

The address pointer in this instruction points to the QCB of a queue. This instruction tests the referenced queue and sets r to equal the number of items in the queue. Sets the condition codes to EQ when the queue is empty. If the queue is not empty, the instruction sets the condition codes to NE. Leaves the values of CBIT and LINK unchanged. WAIT address Wait 0000000011001101 AP\32

The address pointer in this instruction points to a 16-bit semaphore counter, C. The instruction increments C. If C is greater than 0, either the resource is not available, or the event has not occurred. Removes the PCB from the ready list, suspending the process, and adds it to the wait list associated with the semaphore. It then makes the register set available, turns off the process timer, and goes to the dispatcher to find another process to run. The dispatcher enables interrupts.

If C is less than or equal to 0, the currently executing process continues.

If the instruction places the PCB on the wait list, no general registers are saved. This means that a process cannot depend on these registers to be intact after this instruction occurs. This instruction potentially clears the general, floating, and XB registers.

Leaves CBIT, LINK, and the condition codes unchanged.

For more information about semaphores, the dispatcher, PCBs, and wait lists, refer to Chapter 9 of the System Architecture Reference Guide.

Note

This is a restricted instruction.

X R, address Exclusive OR Fullword 1 0 0 0 1 1 DR\3 TM\2 SR\3 BR\2 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Performs an exclusive OR of the contents of the specified R with the 32-bit value contained in the location specified by EA. Stores the result in the specified R. Leaves the values of CBIT, LINK, and the condition codes unchanged.

### Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

XAD

Decimal Add 0 0 0 0 0 0 1 0 0 1 0 0 0 0 0 0

Performs a decimal arithmetic operation under control of FARO, FAR1, and GR2.

FARO contains the address of field 1. FAR1 contains the address of field 2. GR2 contains the control word; fields B and C of the control word specify the decimal operation to be performed, as shown in Table 3-13.

|   | В | I | CB | 1 | Operation | I | Destination |
|---|---|---|----|---|-----------|---|-------------|
| i | 0 | 1 | 0  | 1 | +F1+F2    | 1 | F2          |
| 1 | 0 | 1 | 1  | 1 | +F1-F2    | 1 | F2          |
| 1 | 1 |   | 0  | 1 | -F1+F2    |   | F2          |
| 1 | 1 | 1 | 1  | 1 | -F1-F2    | 1 | <b>F2</b>   |

Table 3-13 XAD Decimal Operations

The scale differential field in the control word specifies the difference in the decimal point alignment between F1 and F2, as follows:

SD Relation of Fl and F2

SD>0 F1 > F2

SD=0 F1 = F2

SD<0 F1 < F2

If the T bit is set to 1, the results are forced positive. If the add operation results in an overflow, a decimal exception occurs. If no overflow occurs, the XAD instruction resets CBIT to 0 to indicate success.

If a decimal exception occurs and bit 11 of the keys contains a 0, the instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

The registers used are GRO, GR1, GR3, GR4, GR6, FARO, FAR1, FIRO, and FIR1. At the end of the instruction, the contents of these registers are indeterminate. The value of LINK is also indeterminate. The condition codes reflect the state of F2 after the decimal operation. (See Appendix A.)

XBID Binary to Decimal Conversion 0 0 0 0 0 0 1 0 0 1 1 0 0 1 0 1

Converts a binary number to a decimal number. FARO contains the decimal field address. GR2 contains the control word. This instruction uses fields A, E, and H of the control word. H specifies the length of the binary number and its location, as follows:

- H Length Location
- 0 16 bits GR3 register, high side
- 1 32 bits GR3 register
- 2 64 bits DAC1 register

Converts the specified binary integer to a decimal integer and stores the result in the location specified by FARO. Leaves the values of LINK indeterminate. Overflow results in a decimal exception. If no overflow occurs, resets CBIT to 0. The values of the condition codes are indeterminate.

The registers used are GRO, GR1, GR3, GR4, GR6, FARO, and FIRO. At the instruction's end, the contents of the registers are indeterminate.

When the source register contains all zeros, the destination register will contain all zeros.

If a decimal exception occurs and bit 11 of the keys contains a 0, the instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

### Note

The XBID instruction does not use or modify FAR1, FIR1, or FAC1.

XCM

Decimal Compare 0000001001000010

Compares two decimal numbers and sets the condition codes depending on the result of the compare. Uses the G field of the control field to adjust the two numbers before the compare, as follows:

## G Field Decision

- >0 Low-order digits of Fl only affect the initial borrow from the low-order digit of F2.
- <0 Assume Fl is zero-extended with low zeros.</p>

FARO contains the address of field 1 (F1). FAR1 contains the address of field 2 (F2). GR2 contains the control word. This instruction uses fields A, B, C, E, F, G, and H of the control word.

The registers used are GRO, GR1, GR3, GR4, GR6, FIRO, and FIR1. At the end of this instruction, the contents of these registers are indeterminate. When there is no decimal exception, CBIT is reset to 0. (This instruction cannot cause a decimal exception.) Leaves the value of LINK indeterminate. The condition codes reflect the result of the comparison, as follows.

- CC Test Result
- GT F2 > F1
- EQ F2 = F1
- LT F2 < F1

XDTB Decimal to Binary Conversion 0 0 0 0 0 0 1 0 0 1 1 0 0 1 1 0

Converts a decimal string to a binary string. FARO contains the address of the decimal string. GR2 contains the control word.

This instruction uses the A, E, and H fields. Field H specifies the length of the binary string and its location, as shown below.

H Length Destination Register

00 16 bits GR2H

- 01 32 bits GR2
- 10 64 bits GR2/GR3

Converts the decimal string to a binary string of the specified type and stores it in the specified register. A conversion error causes a decimal exception. If no decimal exception occurs, the instruction sets CBIT to 0. The values of LINK and the condition codes are indeterminate.

The registers used are GRO, GR1, GR3, GR4, GR6, FARO, and FIRO. At the end of the instruction, the contents of these registers are indeterminate.

If a decimal exception occurs and bit 11 of the keys contains a 0, the instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

Note

This instruction does not use or modify FAR1, FIR1, or FAC1.

XDV Decimal Divide 0 0 0 0 0 0 1 0 0 1 0 0 1 1 1

Divides a decimal number, D2, by another, D1, and stores the quotient and remainder in the location of D2.

FARO contains the address of D1. FAR1 contains the address of D2. L contains the control word. This instruction uses fields A, B, C, E, F, and H.

Both decimal numbers must be in trailing sign embedded format. In addition, D2 must contain a number of leading zeros equal to the length of D1.

The XDV instruction divides the two numbers. After the divide, the location of D2 contains the quotient of length (D2 length - D1 length) followed by the remainder of length (D1 length). Since D2 had leading zeros, no overflow can occur.

If the T bit contains a 1, the results will be forced positive. For more information about decimal arithmetic, refer to Chapter 6 of the System Architecture Reference Guide.

The registers used are GRO, GR1, GR3, GR4, GR6, FARO, FAR1, FLRO, and FLR1. At the end of the instructions, the contents of these registers are indeterminate.

At the end of the instruction, the condition codes, LINK, FARO, and FAR1 contain undefined results. If no overflow occurs, CBIT is reset to 0.

If D1 is 0, overflow occurs and causes a decimal exception. Decimal exceptions also occur if D1 or D2 has the incorrect data type or if the length of D2 is less than that of D1. If no decimal exception occurs, the instruction resets CBIT to 0.

If a decimal exception occurs and bit 11 of the keys contains a 0, the instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the System Architecture Reference Guide for more information.

XED Numeric Edit 0 0 0 0 0 0 1 0 0 1 0 0 1 0 1 0

Edits the contents of a string under control of a subprogram. The registers used are GR2, XB, FARO, FAR1, and FLRO. At the end of the instruction, the contents of these registers and the CBIT, LINK, and condition codes are indeterminate.

FARO contains the address of the source string. The source string must be leading separate sign type and must have at least the same number of decimal digits and the decimal point alignment as called for in the edit subprogram.

FAR1 contains the address of the destination string. Bits 1 to 8 of GR2 contain the floating character; bits 9 to 16, the status register. Bits 17 to 24 of GR2 contain the number of remaining bytes to be processed (used if a fault or interrupt occurs). Bits 25 to 32 of GR2 contain the suppression character whose initial value is determined by bit 12 of the keys ('240 if bit 12 contains 0; '40 if bit 12 contains 1). XB contains the address of the edit subprogram. The instruction uses an edit subprogram to alter a source string and store the edit result in a destination location(s). To set up, perform a decimal move to correct the type, alignment, and length of the number to be edited. Next, use a LCEQ instruction to set up the initial contents of the register.

Each 16-bit halfword in the edit subprogram has the format shown in Figure 3-4, where:

- L is 1 if this 16-bit halfword is the last halfword in the subprogram,
  - 0 if it is not the last halfword;
- E is a suboperator;
- M is a suboperator modifier.

|   | 1 | 2 | ; ; | 3 | 4 |   | 8 | 9 |   | 16 |
|---|---|---|-----|---|---|---|---|---|---|----|
| 1 | L | I | 00  | 1 |   | Е |   |   | М |    |



The XED instruction uses several variables internally to control the edit subprogram. These are shown in Table 3-14. There are 17 edit suboperators, shown in Table 3-15.

Table 3-14 XED Internal Variables

|      | Var  | Definition                                                                                                                                                                                | 1              |
|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
|      | SC   | <ul> <li>Zero suppression character; contained in B. Initial</li> <li>value is the space character ('240 or '40 if bit 12</li> <li>of the keys contains 0 or 1, respectively).</li> </ul> | <br> <br> <br> |
|      | FC   | Floating edit character; contained in GR2. Initial<br>value is not defined.                                                                                                               | 1              |
| <br> | SIGN | <ul> <li>Sign of the source field. The first character fetch</li> <li>sets up the value of this variable.</li> </ul>                                                                      |                |
| 1    | SIG  | End zero suppression flag.                                                                                                                                                                | <br>           |

Table 3-15 XED Suboperators

\_\_\_\_

| Subop                                | Mnem                                                     | Name and Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                      | ZS<br> <br> | Zero Suppress. Fetches M digits from the source<br>field consecutively, each time checking SIG. If<br>SIG is 1, copies the digit into the destination<br>string. If SIG is 0 and the digit is not 0,<br>inserts the floating character (if defined)<br>and copies the digit into the destination field.<br>If SIG is 0, the digit is not 0, and the<br>floating character is not defined, sets the SIG<br>flag and copies the digit into the destination.<br>If SIG and the digit are both 0, substitutes<br>SC for the 0 digit in the destination field. |
| 01<br>                               |                                                          | Insert Literal. Copies M into the<br>destination string. Increments XB and FAR1 by 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 02<br>                               | I SS                                                     | Set Suppress Character. Sets SC to M and I increments XB by 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 03<br> <br>                          | ICS<br> <br> <br>                                        | Insert Character. If SIG is 1, copies M into the<br>destination string. If SIG is 0, copies SC into I<br>the destination string. Increments XB and FAR1 I<br>by 1.                                                                                                                                                                                                                                                                                                                                                                                        |
| 04<br> <br> <br> <br> <br> <br> <br> | ID<br> <br> <br> <br> <br> <br> <br> <br> <br>           | Insert Digits. If SIG is 0, and FC is defined,<br>copies FC and M digits into the destination field<br>then sets SIG to 1. Increments XB by 1, FARO by<br>M, and FARI by M+1. If SIG is 0 and FC is not<br>defined, sets SIG to 1 and copies M digits from<br>the source to the destination. Increments XB by<br>1 and both FARO and FARI by M. If SIG is 1,<br>copies M digits from the source to the<br>destination and increments XB by 1 and both FARO  <br>and FARI by M.                                                                            |

# Table 3-15 (continued) XED Suboperators

| Subop                      | Mnem               | Name and Description                                                                                                                                                                                                                                                                                                                                            |
|----------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 05                         | I ICM              | Insert Character if Minus. If SIGN = 0, copies<br>M into the destination string. If SIGN = 1,                                                                                                                                                                                                                                                                   |
| <br> <br>  06<br>          | <br>  ICP<br> <br> | Copies SC into the destination string.<br>I Increments both SB and FAR1 by 1.<br>I Insert Character if Plus. If SIGN = 0, copies M<br>i into the destination string. If SIGN = 1,<br>copies SC into the destination string.                                                                                                                                     |
| 07                         | SFC                | Set Floating Character. Sets FC to M and I increments VB by 1                                                                                                                                                                                                                                                                                                   |
| 10                         | SFP                | Set Floating if Plus. If SIGN = 0, sets FC to M.                                                                                                                                                                                                                                                                                                                |
| i 11                       | SFM                | Set Floating if Minus. If SIGN = 1, sets FC to M. I<br>I Strong if Minus. If SIGN = 1, sets FC to M. I                                                                                                                                                                                                                                                          |
| 12                         | SFS                | Set Floating to SIGN. If SIGN = 0, sets FC to<br>253. If SIGN = 1, sets FC to 255. Increments                                                                                                                                                                                                                                                                   |
| <br>  13<br>               | <b>JZ</b>          | XB by 1.<br>Jump if Zero. If the condition flag in A = 0,<br>increments XB by 1. If the condition flag in A                                                                                                                                                                                                                                                     |
| <br>  14<br>               | FS                 | = 1, adds M to XB and then increments XB by 1.         Fill with Suppression Characters.         Copies SC         M times into the destination string.                                                                                                                                                                                                         |
| <br>  15<br> <br>          | SF  <br>     <br>  | XB by I and FARI by M.<br>Set Significance. If SIG = 0 and FC <> 0, inserts  <br>FC into the destination string, sets SIG to 1,  <br>and increments XB and FARI by 1. If SIG = 0 and  <br>FC = 0, sets SIG to 1 and increments XB and FARI  <br>by 1 If SIG = 1 increments XB by 1                                                                              |
| 16 1<br>1                  | IS                 | Insert Sign. If SIGN = 0, copies '253 into the<br>destination string. If SIGN = 1, copies '255  <br>into the destination string Increments XB by 1                                                                                                                                                                                                              |
| <b>17</b>  <br>     <br>   |                    | Suppress Digits. Fetches M digits from the source  <br>string and checks if they are '260. If the source  <br>digit = '260, inserts SC into the destination  <br>string. If the source digit <> '260, copies the  <br>source digit into the destination string.  <br>Increments XB by   and both FARO and FARI by M                                             |
| 20  <br>     <br>     <br> |                    | Embed Sign. Fetches M digits from the source  <br>string. If SIGN = 0, copies each digit into the  <br>destination string. If SIGN = 1, embeds a minus  <br>sign into each digit before copying it into the  <br>destination string. Table 6-15 shows the  <br>characters used to represent the sign/digit  <br>combinations. A } symbol represents negative 0. |

XH r, address
 Exclusive OR Halfword
 1 0 1 0 1 1 DR\3 TM\2 SR\3 BR\2
 [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Performs an exclusive OR of the contents of the specified r with the 16-bit value contained in the location specified by EA. Stores the result in r. Leaves the values of CBIT, LINK, and the condition codes unchanged.

### Note

This instruction also has a register-to-register and an immediate form. See Appendix B for more information.

XMP Decimal Multiply 000000100100100

Multiplies one decimal number, M, by another, Dl, and stores the result in D2's location in memory. M is right justified in field D2 at the start of the operation.

FARO contains the address of D1. FAR1 contains the address of D2. GR2 contains the control word; this instruction uses fields A, B, C, E, F, G, H, and T. Field G, the scale differential, must contain the number of decimal digits in M.

The number of decimal digits in D2 is greater than or equal to the number of decimal digits in D1 plus the number of decimal digits in M (specified by G). Normally, the digits to the left (more significant side) of M are zeros. If this is not the case, then a partial product field is added in.

The instruction multiplies M by Dl and stores the result in the location specified by FAR1. The result of the multiply is:

Dl x M + partial product field

The partial product field is equal to:

length(D2) - M.

The partial product field is left justified in D2's location. The maximum partial product added in per traverse of the multiplicand is:

source digits + multiplier digits processed

There is also an implied weighting of the partial product field. The weighting is:

### 10 \*\* multiplier digits

If the T bit contains a 1, the results are forced positive.

The registers used are GRO, GR1, GR3, GR4, GR6, FARO, FAR1, and XB. At the end of this instruction, the contents of these registers are indeterminate. At the end of the XMP instruction, the condition codes reflect the state of the result. (See Appendix A.) Overflow causes a decimal exception. If no overflow occurs, XMP resets CBIT to O. LINK contains undefined results.

A decimal exception occurs if there are more potential or actual product digits than there is space in D2. If a decimal exception occurs and bit 11 of the keys contains a 0, the instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the <u>System</u> Architecture Reference Guide for more information.

XMV Decimal Move 0000001001000001

Moves a string of characters from one location to another.

FARO contains the address of the source string. FAR1 contains the address of the destination string. GR2 contains the control word. This instruction uses fields A, B, D, E, F, G, H, and T.

The instruction moves the contents of the source field into the destination field from right to left. If the B field in the control word is 1, the instruction changes the sign of the source field during the move. If the D field in the control word is 1 and the scale differential is greater than 0, the instruction rounds the source field during the move. If the scale differential (from the H field) is less than 0, the instruction pads the source field with SD trailing zeros before transferring.

If the T bit is set to 1, the result will be forced positive.

An overflow causes a decimal exception. If no decimal exception occurs, the instruction resets CBIT to 0. At the end of the instruction, LINK, FARO, and FAR1 contain undefined results. The values of the condition codes reflect the state of the destination field after the move. (See Appendix A.) If a decimal exception occurs and bit 11 of the keys contains a 0, the XMV instruction sets CBIT to 1. If bit 11 contains a 1, the instruction sets CBIT to 1 and causes a decimal exception fault. See Chapter 10 of the System Architecture Reference Guide for more information about decimal exceptions.

### Note

The source and destination strings may not overlap in memory.

ZCM Compare Character Field 0 0 0 0 0 0 1 0 0 1 0 0 1 1 1 1

Compares two fields and sets the condition codes depending on the result of the compare. Uses registers GR3, GR4, FARO, FAR1, FLRO, and FLR1. At the end of this instruction, the contents of these registers are indeterminate.

FARO contains the address of field 1 (F1). FIRO contains an integer specifying the length of F1. FAR1 contains the address of field 2 (F2). FIR1 contains an integer specifying the length of F2.

The instruction compares the contents of F1 and F2 on a byte by byte basis. If the fields are not of equal length, the instruction automatically extends the shorter string with space characters. Sets the condition codes as a result of the comparison, as follows:

| Result of Compare | Set Condition Codes |
|-------------------|---------------------|
| F1 > F2           | GT                  |
| Fl = F2           | BQ                  |
| F1 < F2           | LT                  |

When the instruction completes execution, the values of CBIT and LINK are indeterminate.

#### Note

This instruction uses GR3, GR4, the FARs, and the FIRs during its operation. Since ZCM does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time.

ZED Character Field Edit 0 0 0 0 0 0 1 0 0 1 0 0 1 0 0 1

Controls an edit subprogram.

Uses the registers GR3, GR4, FARO, FAR1, and FIRO. At the end of this instruction the contents of these registers are indeterminate. Leaves the values of CBIT, LINK, and the condition codes indeterminate.

FARO contains the address of the source string. FLRO specifies the length of the source string. FAR1 contains the address of the

destination string. XB contains the address of the edit subprogram.

The ZED instruction uses the edit subprogram to alter the source string, then loads the edited result into the destination string. The subprogram, addressed by the contents of XB, contains a list of commands, each with the format shown in Figure 3-5, where:

L is l if this command is the last command in the subprogram, O if it is not; E is the edit opcode; M is the edit modifier.





Bits 2 to 6 must be 0.

M, the operator modifier, specifies information E uses when editing the source string. (See Table 3-16.)

E, the edit suboperator, specifies the operation to be performed on the source string. Table 3-16 shows the available values for E.

Table 3-16 **ZED** Suboperators

| Subop | Value | Action                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1                                   |
|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| CPC   |       | Copies characters from the source string into the<br>destination string. If the length of the source<br>string is greater than the contents of the M field,<br>then CPC moves a total of M source characters into<br>the destination string, increments FARO and FAR1 by<br>by M, increments XB by 1, and decrements FIRO by M.<br>If the length of the source string is less than the<br>the contents of the M field, then CPC moves the<br>rest of the source string into the destination<br>string, and then pads the remaining space to be<br>filled with spaces. (See note.) Increments FARO<br>by FIRO and FAR1 by M, increments XB by 1, and<br>and decrements FIRO by FIRO (so FIRO = 0). |                                     |
| INL   | 01    | Inserts M into the destination string and increments both XB and FAR1 by 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1                                   |
| SKC   | 10    | Skips characters in the source string. If the<br>remaining length of the source string is greater<br>than or equal to the contents of the M field, then<br>SKC skips over the next M characters of the source<br>field by incrementing FARO by M and decrementing<br>FIRO by M. If the remaining length of the source<br>string is less than the contents of the M field,<br>SKC skips over FIRO characters in the source string<br>by incrementing FARO by FIRO and decrementing FIRO<br>by FIRO (FIRO = 0). In either case, SKC increments<br>XB by 1.                                                                                                                                          |                                     |
| BLK   | 11    | Inserts M spaces (see note) into the destination<br>string, increments FAR1 by M, and increments XB<br>by 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ONote.<br>  No checka<br>  No advan |

### Note

A space is '240 or '40, depending on whether bit 12 of the keys is 0 or 1. This instruction uses GR3, GR4, the FARs, and the FLRs during its operation. Since ZED does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time.

FLRJ.

ZFIL
 Fill Field with Character
 0 0 0 0 0 0 1 0 0 1 0 0 1 1 1 0

Stores a character into a series of destination bytes. Uses registers GR3, GR4, FARO, FAR1, FLRO, and FLR1. At the end of this instruction, the contents of these registers are indeterminate.

Bits 9 to 16 of GR2 contain the character to be stored. FAR1 contains the starting address of the destination field (byte aligned). FIR1 contains an integer specifying the length of the destination field (in bytes).

The instruction stores the character specified in GR2 in each byte of the destination field. If FLR1 contains 0, no operation takes place. Leaves the values of CBIT, LINK, and the condition codes indeterminate.

### Note

This instruction uses GR3, GR4, the FARs, and the FIRs during its operation. Since ZFIL does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time.

ZM address Zero Memory Fullword 100110011TM\2 SR\3 ER\2 DISPLACEMENT\16

Calculates an effective address, EA. Loads 0 into the 32-bit location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ZMH address Zero Memory Halfword 101110011TM\2 SR\3 ER\2 DISPLACEMENT\16

Calculates an effective address, EA. Loads 0 into the 16-bit location specified by EA. Leaves the values of CBIT, LINK, and the condition codes unchanged.

ZMV Move Character Field 0000001001001100

Moves a character field from one location to another. Uses registers GR3, GR4, FARO, FARI, FIRO, and FIRI. At the end of this instruction, the contents of these registers are indeterminate.

FARO contains the address of the source string (byte aligned). FIRO specifies the length in bytes, N, of the source string. FAR1 contains the address of the destination string (byte aligned). FIR1 specifies the length in bytes, M, of the destination string.

Compares N and M. If N is less than M, the instruction moves the contents of the source string into the destination string followed by M-N space characters. A space character is '240 or '40 when bit 12 of the keys is 0 or 1, respectively. If the destination string is shorter, the instruction moves the first M characters of the source string into the destination string.

When the instruction completes, the values of FARO, FAR1, FLRO, FLR1, CBIT, LINK, and the condition codes are indeterminate.

#### Note

This instruction uses GR3, GR4, the FARs, and the FIRs during its operation. Since ZMV does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time.

This instruction does not work with overlapping strings. See Chapter 6 of the <u>System Architecture Reference Guide</u> for more information.

ZMVD
 Move Characters Between Equal Length Strings
 0 0 0 0 0 0 1 0 0 1 0 0 1 1 0 1

Moves characters from one string to another of equal length. Uses registers GR3, GR4, FARO, FAR1, FLRO, and FLR1. At the end of this instruction, the contents of these registers are indeterminate.

FARO contains the address of the source string. FAR1 contains the address of the destination string. FIR1 contains the number of characters to move, N.

The instruction moves N characters from the source string to the destination string. Characters are moved from lower addresses to higher addresses.

When the ZMVD instruction completes, the values of FARO, FAR1, FLRO, FLR1, CBIT, LINK, and the condition codes are indeterminate.

## Note

The ZMVD instruction uses GR3, GR4, the FARs, and the FIRs during its operation. Since ZMVD does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time.

This instruction does not work with overlapping strings. See Chapter 6 of the <u>System Architecture Reference Guide</u> for more information.

ZTRN Character String Translate 0 0 0 0 0 0 1 0 0 1 0 0 1 0 0 0

Translates a string of characters and stores the translations in the specified destination. Uses registers GR3, GR4, FARO, FAR1, FIRO, and FIR1. At the end of this instruction, the contents of these registers are indeterminate.

FARO contains the address of the source string (byte aligned). FARI contains the address of the destination string (byte aligned). FIRI specifies the length of the source and destination strings. XB contains the address of a translation table. Each byte in the 256-byte table contains an alphabetic character.

The instruction uses the address in FARO to reference a character. It interprets this character as an integer, adding it to the contents of XB to form an address into the translation table. The instruction takes the referenced character in the translation table and writes it into the location specified by FAR1. After storing the character, the instruction increments the contents of FARO and FAR1 by 1, decrements the contents of FIR1 by 1, and repeats the operation until FIR1 contains 0.

At the end of the instruction, FARO and FAR1 point to the location that follows the last byte of the source and destination strings, respectively. FLR1 contains O. Leaves the values of XB, CBIT, LINK, and the condition codes unchanged.

# Note

This instruction uses GR3, GR4, the FARs, and the FIRs during its operation. Since ZTRN does not save the contents of these registers before using them, any data contained in them is overwritten when this instruction executes, unless you save it ahead of time.



τ.

# A Condition Code Information

Bits 9-10 of the keys contain the condition codes. Many arithmetic, branch, skip, jump, and other instructions set these bits to indicate the result of a test (result is less than 0, for example), to indicate whether a value is positive or negative, and so on. Other instructions use the condition code values as Boolean values. The instruction entries in Chapters 2 and 3 of this manual also describe how an instruction affects the state of these bits.

The LT condition code (bit 9 of the keys) contains the extended sign for arithmetic and comparison operations. The extended sign is the sign of the result as if the operation had been done on a machine of infinite precision; thus, LT shows the correct sign of the result despite any overflow. For logic operations, LT reflects the sign of the result.

The EQ condition code (bit 10 of the keys) shows whether or not a 16or 32-bit result is equal to 0.

Table A-1 shows condition code interpretation for comparison, arithmetic, and logic operations.

| LT, EQ<br>  Value     | Comparison                                         | Arithmetic                                                                                                               | <br>  Logic                          |
|-----------------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| 00                    | Register > 0<br>Register > EA<br>Reg 1 > Reg 2     | Signed result > 0<br>Unsigned result <> 0                                                                                | Result <> 0,<br>High-order bit = 0   |
|                       | Register = 0<br>Register = EA<br>Reg 1 = Reg 2     | Result = 0                                                                                                               | Result = 0,<br>High-order bit = 0    |
| 10                    | Register < 0<br>  Register < EA<br>  Reg 1 < Reg 2 | Result < 0                                                                                                               | Result <> 0,<br>  High-order bit = 1 |
| 11<br> <br> <br> <br> | Not working                                        | Possible if largest<br>negative number is<br>added to itself.<br>(CBIT is set to 1<br>as well, to<br>indicate overflow.) | Not working                          |

Table A-1 Interpretation of Condition Codes

# B Addressing Information

As noted in Chapter 1, the 50 Series processors support several kinds of addressing: direct addressing, indexed addressing, indirect addressing, indirect indexed addressing, and general register relative addressing. In addition, these processors also have several modes of addressing, each of which forms addresses differently.

### ADDRESSING MODES AND FORMATS

The addressing modes are listed below. Their formats and address formation are supplied in this Appendix.

- 64V Mode, Short Form
- 64V Mode, Long Form and Indirect Form
- 32I Mode
- 32R Mode
- 64R Mode
- 16S Mode
- 32S Mode

Address trap information is also provided at the end of this Appendix.

### 64V Mode Short Form

Figure B-1 and Table B-1 display and explain 64V mode short form instructions.





Table B-1 64V Mode Short Form Summary

| I   X                                     | S   Disp   Ins                                                             | st Type   Example                                           | Form of EA                                       |
|-------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------|--------------------------------------------------|
|                                           | 0   0-'7@   Din<br>  '10-'377   Din<br>  '400-'777   Din                   | rect   LDA ADR<br>rect  <br>rect@@                          | REG<br>  SB+D<br>  LB+D                          |
|                                           | $0 \mid 0 - '7^{\circ} \mid Inc$                                           | lexed   LDA ADR,X                                           | REG, if D+X<'7;@  <br>  SB+D+X, if D+X>'7@       |
|                                           | '400-'777   Inc<br>  '400-'777   Inc<br>0   0-'7@   Inc                    | lexed@0  <br>lirect   LDA ADR,*                             | I LB+D+X<br>I I(REG)                             |
|                                           | '10-'77'   Inc<br>0   0-'7   Inc                                           | lirect  <br>lirect,   LDA ADR,X*                            | I(PB+D)<br>  I(REG), if D+X<'7;@ <br>  I(PB+D+X) |
|                                           | י י <u>ווע</u><br>ו י10-יזק ו Inc                                          | lirect,   LDA ADR,X*                                        | if D+X>'7@<br>  I(PB+D+X)                        |
|                                           | pre:<br>  100-1777   Inc<br>  post                                         | indexed  <br>lirect,   LDA ADR,*1<br>tindexed               | <br>  I(PB+D)+X<br>                              |
|                                           | 1   '-340- '+377   Di:<br>1   '-340- '+377   In:<br>1   '-340- '+377   In: | rect   LDA ADR<br>dexed   LDA ADR, 1<br>direct   LDA ADR, * | P+D<br>  P+D+X<br>  I(P+D)                       |
| 1 <b>1</b>   <b>1</b>  <br>      <b>1</b> | 1   '-340- '+377   Inc<br>      pre:                                       | direct,   LDA ADR,1*<br>indexed                             | I(P+D+X)<br>                                     |

## Notes to Table B-1

- @ This table assumes segmented mode (modals bit 14 = 1). For nonsegmented mode, the displacement range is 0 to '37, rather than 0 to '7. This means that the range '10 to '377 changes to '40 to '377 in nonsegmented mode. The range '400 to '777 remains unchanged.
- @@ In these address forms, the displacement offsets the contents of LB by '400 (bit 8=1). To compensate for this, set the contents of LB to the current value of the link frame minus '400. For example, if the segment number in LB is '4002 and the offset number in the displacement is '177400, the offset of '400 gives the location of the link frame as segment number '4002, offset number 0.

This mode allows one level of indexing, and one of indirection.

REG refers to a location in the register file. See <u>Address</u> Traps at the end of this chapter.

The instructions DFLX, FLX, JSX, LDX, LDX, QFLX, STX, and STY do not do indexing. The effective address is formed as if bit 2 = 0.

## 64V Mode, Long Form and Indirect Form

Figure B-2 and Table B-2 display and explain 64V mode long and indirect form instructions.



\* For quad operations only.

\*\* This indirect format is used only by a few instructions; most use the 32-bit form.

> 64V Mode Formats, Long Form and Indirect Form Figure B-2

| I        | X | Y   | BRI           | Instruction Type | Example     | Form of EA     |
|----------|---|-----|---------------|------------------|-------------|----------------|
| ,<br>, 0 | 0 | 0   | 1 <b>00</b> 1 | Direct           | LDA ADR     | <b>PB/D</b>    |
| 1        | 1 | I   | <b>01</b>     |                  |             | I SB+D I       |
| 1        | I |     | 10            |                  |             | I LB+D I       |
| ŀ        | i |     | 11            |                  |             | I XB+D I       |
| 10       | 0 | 1   | I 00 I        | Indexed by Y     | LDA ADR,Y   | I PB/D+Y I     |
| .        |   | I   | 01            |                  | Ì           | I SB+D+Y I     |
| 1        | I |     | 10            |                  |             | I LB+D+Y I     |
| 1        | I | 1   | 11            |                  |             | I XB+D+Y I     |
| 0        | 1 | 0   | I 00 I        | Indexed by X     | LDA ADR,X   | I PB/D+X I     |
|          | I |     | 01            |                  | l           | I SB+D+X I     |
|          | 1 | 1   | 10            |                  | ł           | I LB+D+X       |
|          | I | l I | 11            |                  |             | I XB+D+X I     |
| I 0 I    | 1 | 11  | 1 <b>00</b> 1 | Indirect         | LDA ADR,*   | I(PB/D)        |
| 1        | l |     | I 01 I        |                  |             | <b>I(SB+D)</b> |
| 1        | 1 |     | I 10 I        |                  | l           | I I(LB+D)      |
|          | I | Į I | 11            |                  |             | I(XB+D)        |
| 1        | 0 | 0   | I 00 I        | Preindexed by Y  | LDA ADR,Y*  | I(PB/D+Y)      |
|          | I | l I | I 01 I        |                  |             | I(SB+D+Y)      |
|          | 1 |     | 10            |                  | l           | I(LB+D+Y)      |
|          | I |     | 11            |                  |             | I(XB+D+Y)      |
| 1        | 0 | 1   | I <b>00</b> I | Postindexed by Y | LDA ADR, *Y | I(PB/D)+Y      |
| 1        | I | i   | 01            |                  | l           | I(SB+D)+Y      |
| 1        | I | I   | 10            |                  | l           | I(LB+D)+Y      |
|          | I | I   | 11            |                  | 1           | I(XB+D)+Y      |
| 1        | 1 | 0   | 00            | Preindexed by X  | LDA ADR,X*  | I(PB/D+X)      |
|          | I | 1 1 | 01            |                  | l           | I(SB+D+X)      |
| 1        | I | ļ   | 10            |                  | l           | I(LB+D+X)      |
| 1        | ( | l   | 11            | 1                | ł           | I(XB+D+X)      |
| 1        | 1 | 11  | I 00 I        | Postindexed by X | LDA ADR, *X | I(PB/D)+X      |
| 1        | 1 | l I | 01            |                  | l           | I(SB+D)+X      |
| 1        | I | I   | 10            |                  |             | I(LB+D)+X      |
| 1        | I | 1   | 11            |                  | l           | I I(XB+D)+X    |

Table B-2 64V Mode Long Form, Indirect Summary

### Notes to Table B-2

The processor performs X and Y indexing and 32-bit word (inter-segment) indirection.

PB/D indicates that the displacement is relative to the origin of PB. PB specifies the segment number (the offset must be 0); the displacement specifies the offset.

All displacements are within the range 0 to '1777777.

The instructions DFLX, FLX, JSX, LDX, LDY, QFLX, STX, and STY do not do indexing. The effective address is formed as shown in Table B-3. Bit 2, the X bit, is used as part of the opcode in these instructions.

| I | 1 | X | I | Y |   | Instruction Type |
|---|---|---|---|---|---|------------------|
| 0 |   | 0 |   | 0 |   | Direct           |
| 0 | Т | 0 | I | 1 | Т | Direct           |
| 0 | I | 1 | 1 | 0 | I | Direct           |
| 0 | Т | 1 | I | 1 | I | Direct           |
| 1 | T | 0 | T | 0 | I | I(A)             |
| 1 | Т | 0 | T | 1 | T | I(A)             |
| 1 | 1 | 1 | T | 0 | T | I(A)             |
| 1 | I | 1 | T | 1 | T | I(A)             |

Table B-3 Address Formation for Nonindexing Instructions

# Notes to Table B-3

For the earlier processors listed in "About This Book", see Appendix B for information on their address formation for nonindexing instructions.

The symbol <u>A</u> in Table B-3 represents the value calculated from the base register (PB, SB, LB, or XB) and displacement in the instruction.

321 Mode

Figure B-3 and Table B-4 display and explain 321 mode instructions.

L 1 67 910 11 12 14 15 16 17 32 | OP | DR | TM | SR | BR | DISPLACEMENT | Instruction Format\* 1 2 3 4 5 16 17 32 | F | RING | O | SEGMENT | OFFSET 1 Indirect Pointer Format (Short Form) 1 2 3 4 5 16 17 32 33 36 37 48 | F | RING | 1 | SEGMENT | OFFSET | BIT# | RESERVED | Indirect Pointer Format (Long Form) 1 2 3 4 5 16 17 32 | F | RING | B | SEGMENT | OFFSET 1 C Language Pointer\*\* 16 17 32 1 INSTRUCTION BITS 17 TO 32 | ZEROES | Immediate Type 1\*\*\* 1 16 17 32 \_\_\_\_\_\_ \_\_\_\_\_ SIGN EXTENSION | INSTRUCTION BITS 17 TO 32 | Immediate Type 2\*\*\* 56 57 89 1 1 64 ZEROES | BITS 25 TO 32 | | | | BITS 17 TO 24 | ------\_\_\_\_\_ ----- | Immediate Type 3 (Floating Point)\*\*\*, \*\*\*\*

> 32I Mode Formats Figure B-3

## Notes to Figure B-3

- \* TM is the tag modifier which, in combination with the SR and BR fields, specifies the instruction type.
- \*\* The C language pointer is not available for the earlier processors listed in "About This Book".
- \*\*\* The instruction specifies the immediate type to use. During instruction execution, the processor forms the immediate in the appropriate format and stores it internally for use in the operation as shown in Figure B-3.
- \*\*\*\* Bits 1 to 8 of Immediate Type 3 are formed from I mode instruction bits 17 to 24; bits 57 to 64 from I mode instruction bits 25 to 32.

| 1                        | TM                    |                     | SR        |                | BR | 1         | Instruction Type                                                              |                | EA (Segment)                                                        |                 | EA (Off:                                          | set)           |
|--------------------------|-----------------------|---------------------|-----------|----------------|----|-----------|-------------------------------------------------------------------------------|----------------|---------------------------------------------------------------------|-----------------|---------------------------------------------------|----------------|
| <br> <br> <br> <br> <br> | 3<br>3<br>2<br>2<br>1 | <br> <br> <br> <br> | 0 X 0 X 0 | <br> <br> <br> |    |           | Indirect<br>Indirect postindexed<br>Indirect<br>Indirect preindexed<br>Direct | <br> <br> <br> | I(5 to 16)<br>I(5 to 16)<br>I(5 to 16)<br>I(5 to 16)<br>BR(5 to 16) | )<br> <br> <br> | I(D+BR)<br>(I(D+BR)<br>I(D+BR)<br>I(D+BR+<br>D+BR | ))+SRH<br>SRH) |
| Т                        | 1                     | I                   | >0        | Ι              | -  | Ι         | Indexed                                                                       | I              | BR(5 to 16)                                                         | l               | D+BR+SRI                                          | H              |
| 1                        | 0                     | 1                   | 0-7       | 1              | 0  |           | Register-to-register                                                          |                |                                                                     |                 |                                                   |                |
| 1                        | 0                     | ļ                   | 0         | I              | 1  | 1         | Immediate type 1                                                              | 1              |                                                                     | 1               |                                                   |                |
| 1                        | 0                     | 1                   | X         | 1              | 1  | I         | Immediate type 2                                                              | 1              |                                                                     |                 | <b>-</b>                                          |                |
| ł                        | 0                     | 1                   | 0         | ł              | 2  | ł         | Immediate type 3                                                              | 1              |                                                                     | 1               |                                                   |                |
| I                        | 0                     | I                   | 1         | I              | 2  | I         | Floating register                                                             | I              |                                                                     | l               |                                                   |                |
| 1                        | _                     | I                   |           | I              |    | I         | source (FRO)                                                                  | I              |                                                                     |                 |                                                   |                |
|                          | 0                     | 1<br>1<br>1         | 2         | <br> <br>      | 2  | <br> <br> | Undefined; generates<br>UII (unimplemented<br>instruction) fault              | <br> <br>      |                                                                     | <br> <br>       |                                                   |                |
| 1                        | 0                     |                     | 3         |                | 2  | 1         | Floating register<br>source (FR1)                                             | <br>           |                                                                     | 1<br>           |                                                   |                |
| 1                        | 0                     | 1                   | 4–7       | <br>           | 2  |           | Undefined; generates<br>UII fault                                             |                |                                                                     | <br>            |                                                   |                |
| i<br>I                   | 0                     | 1                   | 0-7       |                | 3  |           | General register<br>relative (undefined                                       | 1              | SR(5 to 16)                                                         | 1               | D+SRL                                             |                |
| i                        |                       | i                   |           |                |    | i         | for the earlier                                                               | I              |                                                                     | I               |                                                   |                |
| i                        |                       | i                   |           | 1              |    | i         | processors listed in                                                          | Ì              |                                                                     | I               |                                                   |                |
| I                        |                       | i                   |           | i              |    | i         | "About This Book")                                                            | I              |                                                                     | ł               |                                                   |                |

### Table B-4 32I Mode Summary

Note to Table B-4

Displacements are within the range 0 to '177777, inclusive.

# 32R Mode

Figure B-4 and Table B-5 display and explain 32R mode instructions.

| 1 2 3 6 7 8 16                  |  |  |  |  |  |  |  |
|---------------------------------|--|--|--|--|--|--|--|
| IIX OP IS I DISPLACEMENT I      |  |  |  |  |  |  |  |
| Short Instruction Format        |  |  |  |  |  |  |  |
|                                 |  |  |  |  |  |  |  |
| 1 2 3 6 7 12 13 14 15 16        |  |  |  |  |  |  |  |
| I I X I OP I 110000 I OP I CB I |  |  |  |  |  |  |  |
| 16-bit Long Instruction Format  |  |  |  |  |  |  |  |
|                                 |  |  |  |  |  |  |  |
| 1 2 3 6 7 12 13 14 15 16 17 32  |  |  |  |  |  |  |  |
| IIXIOPI110000 OPICBIDISPI       |  |  |  |  |  |  |  |
| 32-bit Long Instruction Format  |  |  |  |  |  |  |  |
| 1 2 16                          |  |  |  |  |  |  |  |
| I I ADDRESS I                   |  |  |  |  |  |  |  |
| Indirect Pointer Format         |  |  |  |  |  |  |  |
|                                 |  |  |  |  |  |  |  |
| 1 2 16                          |  |  |  |  |  |  |  |
| I O I ADDRESS I                 |  |  |  |  |  |  |  |
| Final Effective Address Format* |  |  |  |  |  |  |  |
|                                 |  |  |  |  |  |  |  |

32R Mode Formats Figure B-4

# Note to Figure B-4

The final form of an effective address in 32R mode is only 15 bits wide. Special hardware exists to truncate the effective address to this length. The program counter, however, is a full 16 bits wide. Multilevel indirection is a feature of 32R mode.

# Table B-5 32R Mode Summary

| I          | X              | S              | CB         | Displacement         | Instruction Type          | Form of EA    |
|------------|----------------|----------------|------------|----------------------|---------------------------|---------------|
| 0          | 0              | 0              |            | 0 to '777            | Direct                    | 0/D           |
| 0          | 1              | 0              |            | 1 0 to '777 1        | Indexed                   | 0/D+X         |
| 1          | 0              | 0              |            | 0 to '777            | Indirect                  | <b>I(0/D)</b> |
| 1          | 1              | 0              |            | 0 to '77 1           | Indirect, preindexed      | I(O/D+X)      |
| 1          | 1              | 0              |            | 1 '100 to'777 1      | Indirect, postindexed     | I(O/D)+X      |
| I 0        | 0              | 1              |            | '-360 to '+377       | Direct                    | I P+D I       |
| I 0        | 1              | 1              |            | 1'-360 to '+3771     | Indexed                   | I P+D+X I     |
| 1          | 0              | 1              |            | 1'-360 to '+3771     | Indirect                  | I I(P+D) I    |
| 11         | 1              | 1              |            | 1'-360 to '+3771     | Indirect postindexed      | I(P+D)+X      |
| 0          | 0              | 1              | 12         |                      | @Postincrement            | I SP I        |
| 0          | 1              | 1              | 2          |                      | @Postincrement, indirect, | I I(SP)+X I   |
| 1          |                | l              | 1          |                      | postindexed               | I I           |
| 1          | 0              | 1              | 2          |                      | @Postincrement, indirect  | I(SP)         |
| 10         | 0              | 1              | I 3        |                      | #Predecrement             | I SP-1 I      |
| I 0        | 1              | 1              | 13         | I I                  | #Predecrement, indirect,  | I(SP-1)+X     |
| 1          |                | l              | I          | I I                  | postindexed               |               |
| 1          | 0              | 1              | 13         |                      | #Predecrement, indirect   | I(SP-1)       |
| 10         | 0              | 1              | I <b>O</b> | 0 to '177777 1       | *Direct, long reach       | ID I          |
| 10         | 1              | 1              | 0          | 0 to 177777 1        | *Indexed, long reach      | ID+X I        |
| 1          | 0              | 1              | I <b>O</b> | 0 to '177777         | *Indirect, long reach     | I(D)          |
| 1          | 1              | 1              | I <b>O</b> | 0 to 177777 1        | *Indirect, preindexed,    | I(D+X)        |
| I          |                |                | !          |                      | long reach                |               |
| 1          | 1              | 1              | 2          | 0 to '177777 1       | *Indirect, postindexed,   | I(D)+X        |
| I          | l              | I              | I          | I I                  | long reach                | I I           |
| 0          | 0              | 1              | 1          | 0 to '177777 1       | *Direct, stack relative   | I D+SP I      |
| 10         | 1              | 1              | 1          | 0 to 177777 1        | *Indexed, stack relative  | D+SP+X        |
| 11         | 0              | 1              | 1          | 0 to 177777 1        | *Indirect, stack relative | I(D+SP) $ $   |
| 1          | 1              | 1              | 1          | 0 to 177777 1        | *Indirect, preindexed     | I(D+SP+X)     |
| <br>  ¶    | <br>, 7        | <br>  <b>]</b> | <br>  77   | <br>  0 + ~ (1000000 | Sudia Teraure             | י דרדעסטייבי  |
| 1 <b>T</b> | ! <b></b><br>! | ) <b>–</b>     | 10         |                      | stade molativo            |               |
| 1          | I              | I              | l          | 1 I                  | Provin TETOUTAE           |               |
#### Notes to Table B-5

- \* These instruction types use the 32-bit long format shown in Figure B-4.
- @ These instruction types use the 16-bit long format shown in Figure B-4. They also increment the contents of SP by 1 during EA formation.
- # These instruction types use the 16-bit long format shown in Figure B-4. They also decrement the contents of SP by 1 during EA formation.

For all instruction types listed above, address traps can occur when any part of the EA formation results in an address in the range 0 to '7 (segmented mode) or 0 to '37 (unsegmented mode). See the end of this chapter for more information.

The processor performs one level of indexing and multiple levels of indirection.

O/D indicates that the displacement is within Sector O.

The instructions DFLX, FLX, JSX, LDX, LDY, QFLX, STX, and STY do not do indexing. The processor treats the X bit as a 0 to determine what addressing mode to use. For example, if one of these instructions specifies I, X, S, and CB as Oll3, the processor interprets it as OOl3.

# 64R Mode

Figure B-5 and Table B-6 display and explain 64R mode instructions.

| 1                       | 236                                                     | 78                                                       |                                       | 16             |
|-------------------------|---------------------------------------------------------|----------------------------------------------------------|---------------------------------------|----------------|
| <b>I</b>                | X   OP                                                  | SI I                                                     | DISP                                  | <br>I          |
|                         | Short Instr                                             | uction For                                               | mat                                   |                |
|                         |                                                         |                                                          |                                       |                |
| 1 :                     | 2367                                                    | 12 13                                                    | 14 15                                 | 16             |
| III                     | K   OP   1                                              | 10000   0                                                | DP I C                                | <b>B</b> I     |
| 16                      |                                                         |                                                          | -                                     |                |
| 10                      | -bit Long In                                            | struction                                                | Format                                |                |
| 10                      | -bit Long In                                            | struction                                                | Format                                |                |
| 10                      | -bit Long In                                            | struction                                                | Format                                |                |
| 1 2 3                   | -bit Long Ind                                           | struction<br>12 13 14                                    | Format<br>: 15 16                     | 17 3           |
| 1 2 3<br>               | -bit Long In<br>3 6 7<br>                               | 12 13 14<br>                                             | Format<br>15 16                       | 17 3<br>       |
| 1 2 3<br>I X I          | -bit Long In<br>3 6 7<br>OP   1100                      | 12 13 14                                                 | Format<br>15 16<br>CB                 | 17 3<br>  DISP |
| 1 2 3<br>I   X  <br>32  | -bit Long In<br>3 6 7<br>OP   1100<br>-bit Long In      | 12 13 14<br>00   OP<br>struction                         | Format<br>15 16<br>CB<br>Format       | 17 3<br>  DISP |
| 1 2 3<br>I   X  <br>32- | -bit Long In<br>3 6 7<br>OP   1100<br>-bit Long In      | 12 13 14<br>00   OP<br>struction                         | Format<br>15 16<br>CB<br>Format       | 17 3<br>  DISP |
| 1 2 3<br>I   X  <br>32  | -bit Long In<br>3 6 7<br>OP   1100<br>-bit Long In<br>1 | 12 13 14<br>00   OP<br>struction                         | Format<br>15 16<br>CB<br>Format       | 17 3<br>  DISP |
| 1 2 3<br>I   X  <br>32  | -bit Long In<br>3 6 7<br>OP   1100<br>-bit Long In<br>1 | struction<br>12 13 14<br>00   OP<br>struction            | Format<br>15 16<br>CB<br>Format<br>16 | 17 3<br>  DISP |
| 1 2 3<br>I   X  <br>32  | -bit Long In<br>3 6 7<br>OP   1100<br>-bit Long In<br>1 | struction<br>12 13 14<br>00   OP<br>struction<br>ADDRESS | Format<br>15 16<br>CB<br>Format<br>16 | 17 3<br>  DISP |

\*Only a single level of indirection is possible in 64R mode.

64R Mode Formats Figure B-5

\_\_\_\_\_

# Table B-6 v 64R Mode Summary

\_\_\_\_\_

~

| I          | x I          | I S          | CB | Displacement                          | Instruction Type                         | Form of EA   |
|------------|--------------|--------------|----|---------------------------------------|------------------------------------------|--------------|
| 10         | 10           | 0            |    | 0 to '777 1                           | Direct                                   | I 0/D I      |
| 10         | 1            | 0            |    | 1 0 to '777 1                         | Indexed                                  | 0/D+X        |
| 1          | 0            | 0            |    | 1 0 to '777                           | Indirect                                 | I I(O/D) I   |
| 1          | 1            | 0            |    | 1 0 to '77 1                          | Indirect, preindexed                     | I(O/D+X)     |
| 1          | 1            | 0            |    | '100 to '777                          | Indirect, postindexed                    | I(O/D)+X     |
| 10         | 10           | 1            |    | '-360 to '+377                        | Direct                                   | P+D I        |
| 10         | 1            | 1            |    | 1'-360 to '+3771                      | Indexed                                  | ∣ P+D+X ∣    |
| 11         | 10           | 1            |    | 1'-360 to '+3771                      | Indirect                                 | I(P+D)       |
| 1          | 1            | 1            |    | 1'-360 to '+3771                      | Indirect postindexed                     | I(P+D)+X     |
| 10         | 10           | 1            | 2  |                                       | @Postincrement                           | I SP I       |
| 10         | 11           | 1            | 2  |                                       | @Postincrement, indirect,                | I I(SP)+X I  |
| , <b>1</b> | ່ດ           | , <b>,</b> , |    | · · · ·                               | @Postinorement indirect                  | י דרפיס) ו   |
|            |              | ובי          | 3  | l                                     | #Prodecroment:                           |              |
|            | 1 1          |              | 3  | · · · · · · · · · · · · · · · · · · · | #Predecrement indirect                   | T(SP-1)+X    |
|            | 1            |              |    | · · ·                                 | postindexed                              |              |
| 11         | 0            | 1            | 3  | I I                                   | #Predecrement, indirect                  | I(SP-1)      |
| 10         | 10           | 1            | 0  | 0 to '177777                          | *Direct, long reach                      | ID I         |
| I 0        | 1            | 1            | 0  | 0 to '177777 1                        | *Indexed, long reach                     | D+X          |
| 11         | 0            | 1            | 0  | 0 to '177777 1                        | *Indirect, long reach                    | I(D)         |
| 1          | 11           | 1            | 0  | 0 to '177777                          | *Indirect, preindexed,                   | I(D+X)       |
| 1          |              |              |    |                                       | long reach                               |              |
| 1 1        | <b>1</b><br> | 1  <br>      | 2  | 0 to '177777  <br>                    | *Indirect, postindexed,<br>long reach    | I(D)+X  <br> |
| 10         | 0            | 11           | 1  | 0 to '177777                          | *Direct. stack relative                  | D+SP         |
| 10         | 1            | 11           | 1  | 0 to '177777 1                        | *Indexed, stack relative                 | D+SP+X       |
| 1          | 0            | 11           | 1  | 0 to '1777777 1                       | *Indirect, stack relative                | I(D+SP)      |
| 1          | 1            | 11           | 1  | 0 to '177777 1                        | *Indirect, preindexed                    | I(D+SP+X)    |
| Ι          | I            | I I          |    | l I                                   | stack relative                           |              |
| 1          | <b>1</b><br> | 11           | 3  | 0 to '177777  <br>                    | *Indirect, postindexed<br>stack relative | I(D+SP)+X    |
|            |              |              |    |                                       |                                          |              |

#### Notes to Table B-6

For all the instruction types listed in Table B-6, address traps can occur when any part of the EA formation results in an address in the range 0 to '7 (segmented mode) or 0 to '37 (unsegmented mode). See the end of this chapter for more information.

- \* These instruction types use the 32-bit long format shown in Figure B-5.
- @ These instruction types use the 16-bit long format shown in Figure B-5. They also increment the contents of SP by 1 during EA formation.
- # These instruction types use the 16-bit long format shown in Figure B-5. They also decrement the contents of SP by 1 during EA formation.

The processor performs one level of indexing and multiple levels of indirection.

0/D indicates that the displacement is within Sector 0.

The instructions DFLX, FLX, JSX, LDX, LDY, QFLX, STX, and STY do not do indexing. The processor treats the X bit as a 0 to determine what addressing mode to use. For example, if one of these instructions specifies I, X, S, and CB as 0113, the processor interprets it as 0013.

#### 16S Mode

Figure B-6 and Table B-7 display and explain 16S mode instructions.



#### 16S Mode Formats Figure B-6

#### Note to Figure B-6

The final form of effective addresses in S mode are only 14 bits wide. Special hardware exists to truncate the effective address to this length. The program counter, however, is a full 16 bits wide.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Disp   Instruction Type                                                                                                                                                                                                                         | Example                                                                                                    | EA Form !                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| 1       0       1       0       1       0       1         1       0       1       1       1       1       1         1       0       1       1       1       1       1         1       0       1       1       1       1       1         1       1       0       1       1       1       1         1       1       0       1       1       1       1         1       1       0       1       1       1       1         1       1       1       1       1       1       1         1       1       1       1       1       1       1 | 0 to '777   Direct<br>0 to '777   Direct<br>0 to '777   Indexed<br>0 to '777   Indexed<br>0 to '777   Indirect<br>0 to '777   Indirect<br>0 to '777   Indirect preindexed<br>0 to '777   Indirect preindexed<br>0 to '777   Indirect preindexed | <pre>IDA ADR IDA ADR IDA ADR IDA ADR,1 IDA ADR,1 IDA ADR,* IDA ADR,* IDA ADR,* IDA ADR,1* IDA ADR,1*</pre> | 0/D  <br>  C/D  <br>  0/D+X  <br>  0/D+X  <br>  C/D+X  <br>  1(0/D)  <br>  1(C/D)  <br>  1(D+X)  <br>  1(D+X) |

#### Table B-7 16S Mode Summary

#### Notes to Table B-7

The processor performs indexing before resolving each level of indirection.

This mode allows multiple levels of both indexing and indirection.

The instructions, LDX and STX, cannot do indexing. The effective address is formed as if bit 2 = 0.

O/D indicates that the displacement is within Sector O; C/D, within the current sector.

#### 32S Mode

Figure B-7 and Table B-8 display and explain 32S mode instructions.



#### 32S Mode Formats Figure B-7

#### Note to Figure B-7

The final form of effective addresses in S mode are only 15 bits wide. Special hardware exists to truncate the effective address to this length. The program counter, however, is a full 16 bits wide.

| IIXISI Disp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Instruction Type                                                                                                                                          | Example                                                                                                                           | EA Form i |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------|
| 0       0       0       0       0       0       777         0       0       1       0       to       777         0       1       1       0       to       777         0       1       1       0       to       777         0       1       1       1       0       to       777         1       0       0       1       0       to       7777         1       0       1       1       0       to       7777         1       0       1       1       0       to       7777         1       1       0       1       0       to       7777         1       1       1       0       to       7777         1       1       1       0       to       7777         1       1       1       0       to       77777         1       1       1       0       to       77777         1       1       1       0       to       777777         1       1       1       0       to       777777 | <ul> <li>Direct</li> <li>Direct</li> <li>Indexed</li> <li>Indexed</li> <li>Indirect</li> <li>Indirect preindexed</li> <li>Indirect postindexed</li> </ul> | + LDA ADR<br>+ LDA ADR<br>+ LDA ADR,1<br>+ LDA ADR,1<br>+ LDA ADR,*<br>+ LDA ADR,*<br>+ LDA ADR,*<br>+ LDA ADR,*1<br>+ LDA ADR,*1 |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | I THUTTEGE DOSETHUERE                                                                                                                                     | UI LLAS ALR, "I                                                                                                                   |           |

#### Table B-8 32S Mode Summary

#### Notes to Table B-8

The processor performs indexing before resolving each level of indirection.

This mode allows one level of indexing, and multiple levels of indirection.

The instructions, LDX and STX, cannot do indexing. The effective address is formed as if bit 2 = 0.

#### ADDRESS TRAPS

Several of the summaries in the last section specifyd special cases of EA formation when the address is within a particular range. This range of addresses corresponds to registers within the current user register set in the register file. (See Chapter 9 of the System Architecture Reference Guide.) In segmented mode, this range is '0 to '7; in nonsegmented mode, '0 to '37. This range of addresses for segmented and nonsegmented modes is referred to as the <u>ATR</u>, or address trap range, throughout this section.

The registers within the user register set contain information, such as general, base, floating-point, and index registers, and system status and control information. Each time any part of the EA formation generates an address within the ATR, an <u>address trap</u> aborts any read or write to a memory location and instead references the specific register.

Table B-9 summarizes when address traps occur for all modes of addressing and instruction types.

|         | Table | ∋ B-9       |
|---------|-------|-------------|
| Address | Trap  | Information |

| Mode I                               | Inst Type                     | Action                                                                                                                    |
|--------------------------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| 16S  <br>  32S  <br>  32R  <br>  64R | Memory  <br>reference  <br>   | Address trap occurs if the EA falls within the ATR (address trap range). The instruction format or length has no bearing. |
|                                      | Generic                       | Address traps never occur.                                                                                                |
|                                      | Generic AP  <br> <br>         | Address traps do not occur when the processor is fetching the address pointer.                                            |
| 64V                                  | 32-bit<br>memory<br>reference | Address traps never occur.                                                                                                |
| <br> <br>                            | Short  <br>format             | See Table B-10.                                                                                                           |
| <br> <br>                            | 16-bit  <br>  indirect        | Address traps occur if the EA falls within the ATR.                                                                       |
|                                      | 32-bit  <br>  indirect        | Address traps never occur.                                                                                                |
| - 32I                                | All types                     | Address traps never occur.                                                                                                |

When bits 17 to 32 of the program counter contain a value within the ATR and the processor is reading an instruction, an address trap always occurs. The only exception to this is if the machine is operating in 321 mode.

When the processor executes short format instructions in 64V mode, address traps can occur during operand fetches or indirect fetches. Table B-10 lists the conditions that must be present for an address trap to occur.

#### Table B-10

#### Address Trap Action for Short Format Instructions, 64V Mode

| I                         | I X                         | I S                  | I Disp                            |                             | Action                                                                                                                                                                                                                       |
|---------------------------|-----------------------------|----------------------|-----------------------------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>  0                  | 0<br>  0<br>                | 0<br>  0             | 0 to '7<br>  '10 to '37           | <br>7  <br>1                | Takes address trap.<br>Takes address trap only if<br>segmentation is off.                                                                                                                                                    |
| 0                         | 0                           | 0                    | 1 '40 to '377                     | 7                           | Cannot take address trap.                                                                                                                                                                                                    |
|                           |                             | <b>L</b><br>         | -'340 to +'35<br>                 | ן זיז<br>ו                  | Takes address trap if EA (P+D) is within the ATR.                                                                                                                                                                            |
| 0<br> <br> <br> <br> <br> | <b>1</b><br> <br> <br> <br> | 0<br> <br> <br> <br> | OtoATR                            |                             | Takes address trap if D+X is<br>within the ATR. If D+X is<br>outside the ATR, the EA is<br>SB (seg #)   D+X (for the 750, 1<br>850, and 2350 to 9955 II; or<br>SB (seg #)   D+X+SB (offset #)  <br>(for all other mechanics) |
| <br> <br> <br> <br>       | <br> <br> <br> <br>         | <br> <br> <br> <br>  | <br> From ATR to '3<br> <br> <br> | <br> 377<br> <br> <br> <br> | (for all other machines).<br>Cannot take address trap; EA is<br>SB+D+X (for 750, 850, and<br>2350 to 9955 II).<br>All other machines take address trap if D+X is within the ATR.                                             |
| <br>  0                   | <br>  1<br>                 | <br>  1<br>          | '400 to '777<br>  -'340 to +'37   | ן 7<br>  77<br>             | Cannot take address trap.                                                                                                                                                                                                    |
| 1  <br>                   | I <b>O</b>                  | <b>0</b>             | ו 0 to ידי<br>ו                   | י.<br>ו ק                   | Takes address trap if D is                                                                                                                                                                                                   |
| 1<br>                     | <b>0</b><br>                | ,<br>  1<br>         | '<br>  -'340 to +'37              | י<br>1 77<br>ו              | Takes address trap if EA                                                                                                                                                                                                     |
| i 1                       | 1<br>                       | <b>0</b>             | ו 0 to 'יזיז<br>ו                 | י<br>ד ק<br>ו               | Takes address trap if D<'100 and D+X is within the ATR.*                                                                                                                                                                     |
| 1                         | <b>1</b><br>                | 1<br>                | -'340 to +'31<br>                 | <br>                        | Takes address trap if EA (P+D)<br>is within the ATR.*                                                                                                                                                                        |

#### Note to Table B-10

\* The indirect address also takes an address trap if EA is within the ATR.

If an instruction specifies a write operation that could potentially cause an address trap, the instruction loads the data to be written into a temporary register. If a trap occurs, the routine aborts the write to memory. It loads the specified register file location with the contents of the temporary register.

B-20

If the instruction specifies a read operation that causes an address trap, the trap routine aborts the memory read and fetches the contents of a register file location. The trap routine loads the cache from the register file data and allows the processor one cache access before invalidating the cache location.

Table B-11 shows the address trap locations and the registers to which they correspond. For more information on the register file, see Chapter 9 of the System Architecture Reference Guide.

| AT             | I S and R Modes   | V Mode            |
|----------------|-------------------|-------------------|
| · '0           | X I               | I <b>X</b> I      |
| 1 1            | I A               | IA, LH I          |
| '2             | I B               |                   |
| l '3           | I S               | I Y I             |
| · <b>'</b> 4   | FAC bits 1 to 16  | FAC bits 1 to 16  |
| 1 '5           | FAC bits 17 to 32 | FAC bits 17 to 32 |
| ∣ <b>′6</b>    | FAC exponent      | FAC exponent      |
| 1 '7           | PC, LSBs          | PC, LSBs          |
| 10*            | I DTAR3H          | I DTAR3H I        |
| 111*           | FCODEH            | FOODEH I          |
| 12*            | FADDRL            | FADDRL            |
| 13*            | 1                 | 1 1               |
| '14*           | 1                 | I SBH I           |
| 15*            | t                 | I SBL I           |
| 1 16*          | 1                 | I LBH             |
| 17*            | 1                 | I LBL I           |
| 1 '20*         | IDMA cell '20H    | IDMA cell '20H I  |
| '21*           | IDMA cell '20L    | DMA cell '20L I   |
| / 22*          | IDMA Cell '22H    | IDMA cell '22H I  |
| ∣ <b>′23</b> * | I DMA cell '22L   | IDMA cell '22L I  |
| ∣ <b>′24</b> * | IDMA cell '24H    | IDMA cell '24H I  |
| ∣ <b>′25</b> * | IDMA cell '24L    | DMA cell '24L     |
| / '26*         | IDMA Cell '26H    | IDMA cell '26H I  |
| '27*           | I DMA cell '26L   | IDMA cell '26L I  |
| ∣ <b>′30</b> * | IDMA Cell '30H    | IDMA Cell '30H    |
| 1 '31*         | IDMA cell '30L    | IDMA Cell '30L I  |
| 1 '32*         | IDMA Cell '32H    | IDMA Cell '32H I  |
| / 33*          | IDMA cell '32L    | DMA cell '32L     |
| 1 '34*         | IDMA cell '34H    | IDMA cell '34H I  |
| ′35*           | IDMA cell '34L    | IDMA Cell '34L I  |
| '36*           | IDMA cell '36H    | IDMA Cell '36H I  |
| 1 '37*         | IDMA cell '36L    | DMA cell '36L     |

Table B-11 Address Trap/Register File Correspondence

### Note to Table B-11

\* These correspond to user register file locations only in nonsegmented mode.

#### SUMMARY

The fields of a memory reference instruction specify information used to form an effective address. These fields specify which information is to be used in the formation, how the formation is to be done, and -- in conjunction with the rest of the program -- the addressing mode under which the address is to be formed. Depending on the segmentation mode and the EA formation, addresses can reference registers within the current user register file as well as memory locations.

# Instruction Summary Charts

This appendix contains two instruction summary charts: one for S, R, and V modes; another for I mode. Each chart contains a list of instructions for the Prime 50 Series processors. (Appendix E lists those instructions that have been archived.) Each instruction is followed by its octal code, format, function, addressing mode, CBIT, LINK, and condition code information, and a one-line description of the instruction.

The columns in each chart are as follows:

R Restrictions:

| Blank | Regular instruction.                                |
|-------|-----------------------------------------------------|
| R     | Instruction causes a restricted mode fault if       |
|       | executed in other than Ring O.                      |
| Ρ     | Instruction may cause a fault depending on address. |

Mnem A mnemonic name recognized by the assembler PMA.

Opcode Octal operation code portion of the instruction.

RI Register (R) and Immediate (I) forms, if available.

Form

# Format of instruction:

| Mnemonic            | Definition                                             |
|---------------------|--------------------------------------------------------|
| AP<br>BRAN<br>CHAR  | Address Pointer<br>Branch<br>Character                 |
| DECL                | Decimal.<br>Conomi o                                   |
| GEN                 | Generic<br>General De distant and Veneral Defeneration |
| GR                  | General Register non Memory Reference                  |
| IBRN                | I Mode Branch                                          |
| MR.                 | Memory Reference Non I Mode                            |
| MRFR                | Memory Reference Floating Register                     |
| MRGR                | Memory Reference General Register                      |
| MRNR                | Memory Reference Non Register                          |
| PIO<br>RGEN<br>SHFT | Programmed I/O<br>Register Generic<br>Shift            |

Func Function of instruction:

Mnemonic Definition

| ADMOD | Addressing Mode           |
|-------|---------------------------|
| BRAN  | Branch                    |
| CHAR  | Character                 |
| CLEAR | Clear Field               |
| CPIR  | C Language Pointer        |
| DECI  | Decimal Arithmetic        |
| FIELD | Field Register            |
| FLPT  | Floating Point Arithmetic |
| GRR   | General Register Relative |
| INT   | Integer                   |
| INIGY | Integrity                 |
| IO    | Input/Output              |
| KEYS  | Keys                      |
| LOGIC | Logical Operations        |
| LTSTS | Logical Test and Set      |
| MCTL  | Machine Control           |
| MOVE  | Move                      |
| PCTLJ | Program Control and Jump  |
| PRCEX | Process Exchange          |
| QUEUE | Queue Control             |
| SHIFT | Register Shift            |
| SKIP  | Skip                      |

Addressing modes of instructions:

| Mode | Name          |
|------|---------------|
| S    | Sectored      |
| R    | Relative      |
| V    | Virtual (64V) |
| I    | 32I           |

С

М

How instruction affects the CBIT and LINK.

Code Definition

| - | CBIT and LINK are unchanged                    |
|---|------------------------------------------------|
| 1 | CBIT = unchanged; LINK = carry                 |
| 2 | CBIT = overflow status; LINK = carry           |
| 3 | CBIT = overflow status; LINK = indeterminate   |
| 4 | CBIT = shift extension; LINK = shift extension |
| 5 | CBIT = result; LINK = indeterminate            |
| 6 | CBIT and LINK are indeterminate                |
| 7 | CBIT and LINK are loaded by the instruction    |
| 8 | CBIT = result; LINK = unchanged                |
| 9 | CBIT = unchanged; LINK = indeterminate         |
| * | CBIT and LINK values vary among processors;    |
|   | see individual instruction description         |

OC How instruction affects the condition codes.

| Code | Definition                                                 |
|------|------------------------------------------------------------|
| _    | Condition codes are unchanged.                             |
| 1    | Condition codes are set to reflect the result              |
|      | of arithmetic operation or compare.                        |
| 4    | Condition codes are set to reflect result of               |
|      | branch, compare, or logicize operand state.                |
| 5    | Condition codes are indeterminate.                         |
| 6    | Condition codes are loaded by instruction.                 |
| 7    | Condition codes show special results for this instruction. |

Description A brief description of the instruction.

Table C-1 contains a summary of S, R, and V mode instructions. Table C-2 is a summary of I mode instructions. Instructions that have been archived are not in either of these tables; see Appendix E for them.

\_\_\_\_\_\_

| R | Mnem   | Opcode | Form | Func  | M   | С | œ | Description                  |
|---|--------|--------|------|-------|-----|---|---|------------------------------|
|   | AlA    | 141206 | GEN  | INT   | SRV | 2 | 1 | Add One to A                 |
|   | A2A    | 140304 | GEN  | INT   | SRV | 2 | 1 | Add Two to A                 |
|   | ABQ    | 141716 | AP   | QUEUE | V   | _ | 7 | Add Entry to Bottom of Queue |
|   | ACA    | 141216 | GEN  | INT   | SRV | 2 | 1 | Add CBIT to A                |
|   | ADD    | 06     | MR.  | INT   | SRV | 2 | 1 | Add                          |
|   | ADL    | 06 03  | MR   | INT   | V   | 2 | 1 | Add Long                     |
|   | ADLL   | 141000 | GEN  | INT   | V   | 2 | 1 | Add LINK to L                |
|   | ALFA O | 001301 | GEN  | FIELD | V   | 6 | - | Add L to FAR O               |
|   | ALFA 1 | 001311 | GEN  | FIELD | V   | 6 | _ | Add L to FAR 1               |
|   | ALL    | 0414XX | SHFT | SHIFT | SRV | 4 | _ | A Left Logical               |
|   | ALR    | 0416XX | SHFT | SHIFT | SRV | 4 |   | A Left Rotate                |
|   | ALS    | 0415XX | SHFT | SHIFT | SRV | 3 | - | A Arithmetic Left Shift      |
|   | ANA    | 03     | MR   | LOGIC | SRV | - | - | AND to A                     |
|   | ANL    | 03 03  | MR   | LOGIC | V   |   | - | AND to A Long                |
|   | ARGT   | 000605 | GEN  | PCTLJ | V   | 6 | 5 | Argument Transfer            |
|   | ARL    | 0404XX | SHFT | SHIFT | SRV | 4 | - | A Right Logical              |
|   | ARR    | 0406XX | SHFT | SHIFT | SRV | 4 | - | A Right Rotate               |
|   | ARS    | 0405XX | SHFT | SHIFT | SRV | 4 | - | A Arithmetic Right Shift     |
|   | ATQ    | 141717 | AP   | QUEUE | V   | - | 7 | Add Entry to Top of Queue    |
|   | BCEQ   | 141602 | BRAN | BRAN  | V   | _ | - | Branch on Condition Code EQ  |
|   | BOGE   | 141605 | BRAN | BRAN  | V   | _ |   | Branch on Condition Code GE  |
|   | BOGT   | 141601 | BRAN | BRAN  | V   | _ | - | Branch on Condition Code GT  |
|   | BCLE   | 141600 | BRAN | BRAN  | V   |   | - | Branch on Condition Code LE  |
|   | BCLT   | 141604 | BRAN | BRAN  | V   | _ |   | Branch on Condition Code LT  |
|   | BCNE   | 141603 | BRAN | BRAN  | V   | - | - | Branch on Condition Code NE  |
|   | BCR    | 141705 | BRAN | BRAN  | V   | - | - | Branch on CBIT Reset to O    |
|   | BCS    | 141704 | BRAN | BRAN  | V   | - | - | Branch on CBIT Set to 1      |
|   | BDX    | 140734 | BRAN | BRAN  | V   | - | - | Branch on Decremented X      |
|   | BDY    | 140724 | BRAN | BRAN  | V   | - | - | Branch on Decremented Y      |
|   | BEQ    | 140612 | BRAN | BRAN  | V   | - | 4 | Branch on A Equal to O       |
|   | BFEQ   | 141612 | BRAN | BRAN  | V   | - | 4 | Branch on F Equal to O       |
|   | BFGE   | 141615 | BRAN | BRAN  | V   | - | 4 | Branch on F Greater Than or  |
|   |        |        |      |       |     |   |   | Equal to O                   |
|   | BFGT   | 141611 | BRAN | BRAN  | V   | - | 4 | Branch on F Greater Than O   |
|   | BFLE   | 141610 | BRAN | BRAN  | V   | - | 4 | Branch on F Less Than or     |
|   |        |        |      |       |     |   |   | Equal to O                   |
|   | BFLT   | 141614 | BRAN | BRAN  | V   | - | 4 | Branch on F Less Than O      |
|   | BFNE   | 141613 | BRAN | BRAN  | V   | - | 4 | Branch on F Not Equal to O   |
|   | BGE    | 140615 | BRAN | BRAN  | V   | - | 4 | Branch on A Greater Than or  |
|   |        |        |      |       |     |   |   | Equal to O                   |
|   | BGT    | 140611 | BRAN | BRAN  | V   |   | 4 | Branch on A Greater Than O   |
|   | BIX    | 141334 | BRAN | BRAN  | V   | - | - | Branch on Incremented X      |
|   | BIY    | 141324 | BRAN | BRAN  | V   | - | - | Branch on Incremented Y      |
|   | BLE    | 140610 | BRAN | BRAN  | V   |   | 4 | Branch on A Less Than or     |
|   |        | _      |      |       |     |   |   | Equal to 0                   |
|   | BLEQ   | 140702 | BRAN | BRAN  | V   | - | 4 | Branch on L Equal to O       |
|   |        |        |      |       |     |   |   |                              |

Table C-1 S, R, V Mode Instruction Summary

\_\_\_\_

•

| R | Mnem | Opcode | Form | Func  | M   | С | œ | Description                                   |
|---|------|--------|------|-------|-----|---|---|-----------------------------------------------|
|   | BLGE | 140615 | BRAN | BRAN  | V   | _ | 4 | Branch on L Greater Than or<br>Equal to O     |
|   | BLGT | 140701 | BRAN | BRAN  | V   | - | 4 | Branch on L Greater Than 0                    |
|   | BLLE | 140700 | BRAN | BRAN  | V   | _ | 4 | Branch on L Less Than or<br>Equal to O        |
|   | BLLT | 140614 | BRAN | BRAN  | V   | _ | 4 | Branch on L Less Than O                       |
|   | BLNE | 140703 | BRAN | BRAN  | V   | - | 4 | Branch on L Not Equal to O                    |
|   | BLR  | 141707 | BRAN | BRAN  | V   | _ | - | Branch on LINK Reset to O                     |
|   | BLS  | 141706 | BRAN | BRAN  | V   | - | _ | Branch on LINK Set to 1                       |
|   | BLT  | 140614 | BRAN | BRAN  | V   | _ | 4 | Branch on A Less Than O                       |
|   | BMEQ | 141602 | BRAN | BRAN  | V   | - | _ | Branch on Magnitude<br>Condition EQ           |
|   | BMGE | 141706 | BRAN | BRAN  | V   | - | - | Branch on Magnitude<br>Condition GE           |
|   | BMGT | 141710 | BRAN | BRAN  | V   | - | - | Branch on Magnitude<br>Condition GT           |
|   | BMLE | 141711 | BRAN | BRAN  | V   |   | - | Branch on Magnitude<br>Condition LE           |
|   | BMLT | 141707 | BRAN | BRAN  | V   | _ | - | Branch on Magnitude<br>Condition LT           |
|   | BMNE | 141603 | BRAN | BRAN  | V   | - | - | Branch on Magnitude<br>Condition NE           |
|   | BNE  | 140613 | BRAN | BRAN  | V   | _ | 4 | Branch on A Not Equal to 0                    |
|   | CAL  | 141050 | GEN  | CLEAR | SRV | - | _ | Clear A Left Byte                             |
|   | CALF | 000705 | AP   | PCTLJ | V   | 6 | 5 | Call Fault Handler                            |
|   | CAR  | 141044 | GEN  | CLEAR | SRV | _ | _ | Clear A Right Byte                            |
|   | CAS  | 11     | MR   | SKIP  | SRV | 1 | 1 | Compare A and Skip                            |
|   | CAZ  | 140214 | GEN  | SKIP  | SRV | 1 | 1 | Compare A with 0                              |
|   | CEA  | 000111 | GEN  | PCILJ | SR  | _ |   | Compute Effective Address                     |
|   | OGT  | 001314 | GEN  | BRAN  | V   | 6 | 5 | Computed GOTO                                 |
|   | CHS  | 140024 | GEN  | INT   | SRV | - | - | Change Sign                                   |
|   | CLS  | 11 03  | MR   | LOGIC | V   | 1 | 1 | Compare L and Skip                            |
|   | CMA  | 140401 | GEN  | LOGIC | SRV | — | _ | Complement A                                  |
|   | CRA  | 140040 | GEN  | CLEAR | SRV | _ | _ | Clear A to O                                  |
|   | CRB  | 140015 | GEN  | CLEAR | SRV | - | - | Clear B to O                                  |
|   | CRE  | 141404 | GEN  | CLEAR | V   | - | - | Clear E to O                                  |
|   | CRL  | 140010 | GEN  | CLEAR | SRV | _ | _ | Clear L to O                                  |
|   | CRLE | 141410 | GEN  | CLEAR | V   |   | _ | Clear L and E to O                            |
|   | CSA  | 140320 | GEN  | MOVE  | SRV | 5 | - | Copy Sign of A                                |
|   | DAD  | 06     | MR   | INT   | SR  | 2 | 1 | Double Add                                    |
|   | DBL  | 000007 | GEN  | INT   | SR  | _ | _ | Enter Double Precision Mode                   |
|   | DFAD | 06 02  | MR   | FLPT  | RV  | 3 | 5 | Double Precision Floating<br>Add              |
|   | DFCM | 140574 | GEN  | FLPT  | RV  | 3 | 5 | Double Precision Floating<br>Complement       |
|   | DFCS | 11 02  | MR   | FLPT  | RV  | 6 | 5 | Double Precision Floating<br>Compare and Skip |

.

| R | Mnem   | Opcode | Form | Func   | M   | С | œ | Description                                         |
|---|--------|--------|------|--------|-----|---|---|-----------------------------------------------------|
|   | DFDV   | 17 02  | MR   | FLPT   | RV  | 3 | 5 | Double Precision Floating<br>Divide                 |
|   | DFLD   | 02 02  | MR.  | FLPT   | RV  | - | - | Double Precision Floating<br>Load                   |
|   | DFLX   | 15 02  | MR   | FLPT   | V   | - | - | Double Precision Floating<br>Load Index             |
|   | DFMP   | 16 02  | MR   | FLPT   | RV  | 3 | 5 | Double Precision Floating<br>Multiply               |
|   | DFSB   | 07 02  | MR.  | FLPT   | RV  | 3 | 5 | Double Precision Floating<br>Subtract               |
|   | DFST   | 04 02  | MR.  | FLPT   | RV  | - | - | Double Precision Floating<br>Store                  |
|   | DIV    | 17     | MR   | INT    | V   | 3 | 5 | Divide                                              |
|   | DIV    | 17     | MR   | INT    | SR  | З | 5 | Divide                                              |
|   | DLD    | 02     | MR   | MOVE   | SR  | _ | _ | Double Load                                         |
|   | DRN    | 040300 | GEN  | FLPT   | V   | 3 | 5 | Double Round From Quad                              |
|   | DRNM   | 140571 | GEN  | FLPT   | V   | 8 | 5 | Double Round From Quad<br>Towards Negative Infinity |
|   | DRNP   | 040301 | GEN  | FLPT   | V   | 3 | 5 | Double Round From Quad<br>Towards Positive Infinity |
|   | DRNZ   | 040302 | GEN  | FLPT   | V   | 3 | 5 | Double Round From Quad<br>Towards Zero              |
|   | DRX    | 140210 | GEN  | SKIP   | SRV | _ | - | Decrement and Replace X                             |
|   | DSB    | 07     | MR   | INT    | SR  | 2 | 1 | Double Subtract                                     |
|   | DST    | 04     | MR   | MOVE   | SR  | - | _ | Double Store                                        |
|   | DVL    | 17 03  | MR   | INT    | V   | 3 | 5 | Divide Long                                         |
|   | E16S   | 000011 | GEN  | ADMOD  | SRV | - | _ | Enter 165 Mode                                      |
|   | E32I   | 001010 | GEN  | ADMOD  | SRV | - | _ | Enter 321 Mode                                      |
|   | E32R   | 001013 | GEN  | ADMOD  | SRV | _ | - | Enter 32R Mode                                      |
|   | E32S   | 000013 | GEN  | ADMOD  | SRV | _ | _ | Enter 32S Mode                                      |
|   | E64R   | 001011 | GEN  | ADMOD  | SRV | _ |   | Enter 64R Mode                                      |
|   | E64V   | 000010 | GEN  | ADMOD  | SRV |   | - | Enter 64V Mode                                      |
|   | EAA    | 01 01  | MR.  | MOVE   | R   | - | — | Effective Address to A                              |
|   | eafa o | 001300 | AP   | FIELD  | V   | - | - | Effective Address to FAR 0                          |
|   | EAFA 1 | 001310 | AP   | FIELD  | V   | - | - | Effective Address to FAR 1                          |
|   | EAL    | 01 01  | MR.  | PCTLJ  | V   | - | - | Effective Address to L                              |
|   | EALB   | 13 02  | MR   | PCILJ  | V   | — | - | Effective Address to LB                             |
|   | EAXB   | 12 02  | MR   | PCILJ  | V   | - | - | Effective Address to XB                             |
| R | EIO    | 14 01  | MR.  | IO     | V   | - | 7 | Execute I/O                                         |
| R | ENB    | 000401 | GEN  | IO     | SRV | - | - | Enable Interrupts                                   |
| R | ENBL   | 000401 | GEN  | IO     | SRV | - | - | Enable Interrupts (Local)                           |
| R | ENBM   | 000400 | GEN  | IO     | SRV | - | - | Enable Interrupts (Mutual)                          |
| R | ENBP   | 000402 | GEN  | 10     | SRV | - | - | Enable Interrupts (Process)                         |
|   | ERA    | 05     | MR   |        | SRV | - | - | EXCLUSIVE OF TO A                                   |
|   | ERL    | 05 03  | MR   | LUGIC  | V   |   | _ | EXCLUSIVE OK TO L                                   |
|   | fad    | 06 UI  | MK   | LTTLL. | KΛ  | 0 | D | LTOROTHS HOO                                        |

\_\_\_\_\_

\_\_\_\_\_

| FCDQ       140571       GEN       FLPT       V       -       -       Floating Convert Double         FCM       140530       GEN       FLPT       RV       3       5       Floating Complement         FCS       11       01       MR       FLPT       RV       6       5       Floating Compare and Ski         FDEL       140016       GEN       FLPT       V       -       -       Floating Convert Single         Double       FDV       17       01       MR       FLPT       RV       3       5       Floating Divide         FID       02       01       MR       FLPT       RV       -       -       Floating Load         FLOT       140550       GEN       FLPT       R       6       5       Convert Integer to Float<br>Point |      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| FCM       140530       GEN       FLPT       RV       3       5       Floating Complement         FCS       11 01       MR       FLPT       RV       6       5       Floating Compare and Ski         FDEL       140016       GEN       FLPT       V       -       -       Floating Compare and Ski         FDN       140016       GEN       FLPT       V       -       -       Floating Convert Single         Double       FDV       17       01       MR       FLPT       RV       3       5       Floating Divide         FID       02       01       MR       FLPT       RV       -       -       Floating Load         FLOT       140550       GEN       FLPT       R       6       5       Convert Integer to Float<br>Point       | to   |
| FCS       11 01       MR       FLPT       RV       6       5       Floating Compare and Ski         FDEL       140016       GEN       FLPT       V       -       -       Floating Convert Single         Double       Double       Double       -       Floating Divide         FLD       02 01       MR       FLPT       RV       -       -       Floating Load         FLOT       140550       GEN       FLPT       R       6       5       Convert Integer to Float         Point       -       -       -       Floating Load       -       Floating Load                                                                                                                                                                             |      |
| FDEL 140016 GEN FLPT V Floating Convert Single<br>Double<br>FDV 17 01 MR FLPT RV 3 5 Floating Divide<br>FLD 02 01 MR FLPT RV Floating Load<br>FLOT 140550 GEN FLPT R 6 5 Convert Integer to Float<br>Point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | p    |
| FDV 17 01 MR FLPT RV 3 5 Floating Divide<br>FLD 02 01 MR FLPT RV Floating Load<br>FLOT 140550 GEN FLPT R 6 5 Convert Integer to Float<br>Point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | to   |
| FLD 02 01 MR FLPT RV Floating Load<br>FLOT 140550 GEN FLPT R 6 5 Convert Integer to Float<br>Point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |
| FLOT 140550 GEN FLPT R 6 5 Convert Integer to Float<br>Point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ing  |
| FLTA 140532 GEN FLPT V 6 5 Convert Integer to Float<br>Point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ing  |
| FLTL 140535 GEN FLPT V 6 5 Convert Long Integer to<br>Floating Point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |
| FLX 15 01 MR FLPT RV Floating Load Index                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |
| FMP 16 01 MR FLPT RV 3 5 Floating Multiply                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |
| FRN 140534 GEN FLPT RV 3 5 Floating Round                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |
| FRNM 040320 GEN FLPT V 3 5 Floating Round Towards                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |
| Negative Infinity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |
| FRNP 040303 GEN FLPT V 3 5 Floating Round Towards<br>Positive Infinity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      |
| FRNZ 040321 GEN FLPT V 3 5 Floating Round Towards Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ero  |
| FSB 07 01 MR FLPT RV 3 5 Floating Subtract                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |
| FSGT 140515 GEN FLPT RV - 5 Floating Skip If Greater<br>Than O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Þ    |
| FSLE 140514 GEN FLPT RV - 5 Floating Skip If Less Th<br>or Equal to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | an   |
| FSMI 140512 GEN FLPT RV - 5 Floating Skip If Minus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | _    |
| FSNZ 140511 GEN FLPT RV - 5 Floating Skip If Not Equ<br>to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | al   |
| FSPL 140513 GEN FLPT RV - 5 Floating Skip If Plus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |
| FST 04 01 MR FLPT RV 3 5 Floating Store                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |
| FSZE 140510 GEN FLPT RV - 5 Floating Skip If Equal t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ю О  |
| R HLT 000000 GEN MCTL SRV Halt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |
| IAB 000201 GEN MOVE SRV Interchange A and B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |
| ICA 141340 GEN MOVE SRV Interchange Bytes of A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |
| ICL 141140 GEN MOVE SRV Interchange Bytes and Cl<br>Left                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | .ear |
| ICR 141240 GEN MOVE SRV Interchange Bytes and Cl<br>Right                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | .ear |
| ILE 141414 GEN MOVE V Interchange L and E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |
| IMA 13 MR MOVE SRV Interchange Memory and A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 7    |
| R INA 54 PIO IO SR Input to A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |
| R INBC 001217 AP PRCEX V 6 5 Interrupt Notify Beginni<br>Clear Active Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ng,  |
| R INEN 001215 AP PRCEX V 6 5 Interrupt Notify Beginni                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ng   |

# Table C-1 (continued) S, R, V Mode Instruction Summary

| R | Mnem   | Opcode | Form | Func  | M        | С | œ | Description                                     |  |
|---|--------|--------|------|-------|----------|---|---|-------------------------------------------------|--|
| R | INEC   | 001216 | AP   | PRCEX | V        | 6 | 5 | Interrupt Notify End, Clear<br>Active Interrupt |  |
| R | INEN   | 001214 | AP   | PRCEX | V        | 6 | 5 | Interrupt Notify End                            |  |
| R | INH    | 001001 | GEN  | IO    | SRV      | - | _ | Inhibit Interrupts                              |  |
| R | INHL   | 001001 | GEN  | IO    | SRV      |   | _ | Inhibit Interrupts (Local)                      |  |
| R | INHM   | 001000 | GEN  | IO    | SRV      | - | - | Inhibit Interrupts (Mutual)                     |  |
| R | INHP   | 001002 | GEN  | IO    | SRV      |   | _ | Inhibit Interrupts (Process)                    |  |
|   | INK    | 000043 | GEN  | KEYS  | SR       | _ |   | Input Kevs                                      |  |
|   | INT    | 140554 | GEN  | FLPT  | R        | 3 | 5 | Convert Floating Point to<br>Integer            |  |
|   | INTA   | 140531 | GEN  | FLPT  | V        | 3 | 5 | Convert Floating Point to<br>Integer            |  |
|   | INTL   | 140533 | GEN  | FLPT  | V        | 3 | 5 | Convert Floating Point to<br>Integer Long       |  |
|   | IRS    | 12     | MR   | SKIP  | SRV      | - | _ | Increment and Replace Memory                    |  |
| R | IRTC   | 000603 | GEN  | IO    | V        | 7 | 6 | Interrupt Return, Clear<br>Active Interrupt     |  |
| R | IRTN   | 000601 | GEN  | IO    | V        | 7 | 6 | Interrupt Return                                |  |
|   | IRX    | 140114 | GEN  | SKIP  | SRV      | - | _ | Increment and Replace X                         |  |
| R | ITLB   | 000615 | GEN  | MCTL  | V        | 6 | 5 | Invalidate STLB Entry                           |  |
|   | JDX    | 15 02  | MR.  | PCILJ | R        |   | _ | Jump and Decrement X                            |  |
|   | JIX    | 15 03  | MR.  | PCTLJ | R        |   | _ | Jump and Increment X                            |  |
|   | JMP    | 01     | MR   | PCTLJ | SRV      | _ | - | Jump                                            |  |
|   | JST    | 10     | MR   | PCTLJ | SRV      |   |   | Jump and Store                                  |  |
|   | JSX    | 35 03  | MR   | PCTLJ | RV       | - | — | Jump and Save in X                              |  |
|   | JSXB   | 14 02  | MR   | PCTLJ | V        | - | - | Jump and Save in XB                             |  |
|   | JSY    | 14     | MR.  | PCTLJ | V        | - | - | Jump and Save in Y                              |  |
|   | LCEQ   | 141503 | GEN  | LTSTS | V        |   | - | Load A on Condition Code EQ                     |  |
|   | LOGE   | 141504 | GEN  | LTSTS | V        | - | - | Load A on Condition Code GE                     |  |
|   | LOGT   | 141505 | GEN  | LTSTS | V        | - |   | Load A on Condition Code GT                     |  |
|   | LCLE   | 141501 | GEN  | LTSTS | V        | - | - | Load A on Condition Code LE                     |  |
|   | LCLT   | 141500 | GEN  | LTSTS | V        | - | - | Load A on Condition Code LT                     |  |
|   | LCNE   | 141502 | GEN  | LTSTS | V        | - | _ | Load A on Condition Code NE                     |  |
|   | LDA    | 02     | MR   | MOVE  | SRV      | - | _ | Load A                                          |  |
|   | LDC 0  | 001302 | CHAR | CHAR  | V        | - | 7 | Load Character                                  |  |
|   | LDC 1  | 001312 | CHAR | CHAR  | V        | - | 7 | Load Character                                  |  |
|   | LDL    | 02 03  | MR   | MOVE  | V        | - | _ | Load Long                                       |  |
| Ρ | LDLR   | 05 01  | MR.  | MOVE  | V        | - | 5 | Load from Addressed Register                    |  |
|   | LDX    | 35 00  | MR.  | MOVE  | SRV      | - | - | Load X                                          |  |
|   | LDY    | 35 01  | MR   | MOVE  | V        | - | _ | Load Y                                          |  |
|   | LEQ    | 140413 | GEN  | LTSTS | SRV      | - | 4 | Load A on A Equal to U                          |  |
|   | LF     | 140416 | GEN  | LISTS | SRV      | - | 5 | Load False                                      |  |
|   | TPL:FC | 141113 | GEN  | TL2L2 | V<br>17  | _ | 4 | LOAD A ON F Equal to U                          |  |
|   | TRAR   | 141114 | GEN  | TI212 | V        | _ | 4 | For A on r creater man or                       |  |
|   | LFGT   | 141115 | GEN  | LTSTS | <b>V</b> | _ | 4 | Load A on F Greater Than 0                      |  |

\_\_\_\_\_

| R | Mnem          | Opcode | Form | Func  | M   | С | $\infty$ | Description                               |
|---|---------------|--------|------|-------|-----|---|----------|-------------------------------------------|
|   | LFLE          | 141111 | GEN  | LTSTS | V   | _ | 4        | Load A on F Less Than or<br>Foual to O    |
|   | LFLT O        | 001303 | BRAN | FIFID | v   | _ | _        | Load FIR O Immediate                      |
|   | IFIJ I        | 001313 | BRAN | FIED  | v   |   | _        | Load FIR 1 Immediate                      |
|   | LFLT          | 141110 | GEN  | LTSTS | v   | _ | 4        | Load A on F Less Than 0                   |
|   | LFNE          | 141112 | GEN  | LTSTS | v   |   | 4        | Load A on F Not Equal to O                |
|   | LGE           | 140414 | GEN  | LTSTS | SRV | - | 4        | Load A on A Greater Than or<br>Equal to 0 |
|   | LGT           | 140415 | GEN  | LTSTS | SRV |   | 4        | Load A on A Greater Than O                |
| R | LIOT          | 000044 | AP   | MCIL  | V   | 6 | 5        | Load IOILB                                |
|   | LLE           | 140411 | GEN  | LTSTS | SRV | _ | 4        | Load A on A Less Than or                  |
|   |               |        |      |       |     |   | _        | Equal to O                                |
|   | LLEO          | 141513 | GEN  | LTSTS | V   | _ | 4        | Load L on A Equal to 0                    |
|   | LIGE          | 140414 | GEN  | LTSTS | V   | - | 4        | Load L on A Greater Than or               |
|   |               |        |      |       | •   |   | _        | Equal to O                                |
|   | LLGT          | 141515 | GEN  | LTSTS | V   | - | 4        | Load L on A Greater Than O                |
|   | III           | 0410XX | SHFT | SHIFT | SRV | 4 | _        | Long Left Logical                         |
|   | ITTE          | 141511 | GEN  | LTSTS | V   | _ | 4        | Load L on A Less Than or                  |
|   |               |        |      |       |     |   |          | Equal to O                                |
|   | LLLT          | 140410 | GEN  | LTSTS | V   | _ | 4        | Load L on A Less Than O                   |
|   | LLNE          | 141512 | GEN  | LTSTS | V   | _ | 4        | Load L on A Not Equal to O                |
|   | LIR           | 0412XX | SHFT | SHIFT | SRV | 4 | -        | Long Left Rotate                          |
|   | LLS           | 0411XX | SHFT | SHIFT | SRV | 3 | 5        | Long Left Shift                           |
|   | LLT           | 140410 | GEN  | LTSTS | SRV | _ | 4        | Load A on A Less Than 0                   |
|   | LNE           | 140412 | GEN  | LTSTS | SRV | _ | 4        | Load A on A Not Equal to O                |
| R | LPID          | 000617 | GEN  | MCIL  | V   | - | _        | Load Process ID                           |
| R | LPSW          | 000711 | AP   | MCTL  | V   | 7 | 6        | Load Process Status Word                  |
|   | IRL           | 0400XX | SHFT | SHIFT | SRV | 4 | -        | Long Right Logical                        |
|   | LRR           | 0402XX | SHFT | SHIFT | SRV | 4 | _        | Long Right Rotate                         |
|   | IRS           | 0401XX | SHFT | SHIFT | SRV | 4 | _        | Long Right Shift                          |
|   | $\mathbf{LT}$ | 140417 | GEN  | LTSTS | SRV | _ | 5        | Load True                                 |
|   | MPL           | 16 03  | MR   | INT   | V   | * | -        | Multiply Long                             |
|   | MPY           | 16     | MR   | INT   | V   | 3 | -        | Multiply                                  |
|   | MPY           | 16     | MR   | INT   | SR  | 3 | *        | Multiply                                  |
| R | NFYB          | 001211 | AP   | PRCEX | V   | 6 | 5        | Notify                                    |
| R | NFYE          | 001210 | AP   | PRCEX | V   | 6 | 5        | Notify                                    |
|   | NOP           | 000001 | GEN  | MCIL  | SRV | - |          | No Operation                              |
| R | OCP           | 14     | PIO  | IO    | SR  | - | -        | Output Control Pulse                      |
|   | ORA           | 03 02  | MR   | LOGIC | V   | - | -        | Inclusive OR                              |
| R | OTA           | 74     | PIO  | IO    | SR  | - | -        | Output from A                             |
|   | OIK           | 000405 | GEN  | KEYS  | SR  | 7 | 6        | Output Keys                               |
|   | PCL           | 10 02  | MR   | PCILJ | V   | 6 | 5        | Procedure Call                            |
|   | PID           | 000211 | GEN  | INT   | SR  | - | -        | Position for Integer Divide               |
|   | PIDA          | 000115 | GEN  | INT   | V   | - | -        | Position for Integer Divide               |
|   | PIDL          | 000305 | GEN  | INT   | V   | - | -        | Position for Integer Divide<br>Long       |
|   | PIM           | 000205 | GEN  | INT   | SR  | _ | _        | Position after Multiply                   |

Table C-1 (continued) S, R, V Mode Instruction Summary

\_\_\_\_\_

| R | Mnem          | Opcode | Form | Func   | М   | С | œ | Description                           |  |
|---|---------------|--------|------|--------|-----|---|---|---------------------------------------|--|
|   | PIMA          | 000015 | GEN  | INT    | V   | 3 | 5 | Position after Multiply               |  |
|   | PIML          | 000301 | GEN  | TNT    | v   | 3 | 5 | Position after Multiply Long          |  |
|   | PRTN          | 000611 | GEN  | PCTT T | v   | 7 | 6 | Procedure Return                      |  |
| R | PTLB          | 000064 | GEN  | MCTT   | v   | Ġ | 5 | Purde TIR                             |  |
|   | OFAD          | 5 2 2  | MR   | गप.ग्स | v   | 3 | 5 | Quad Precision Floating Add           |  |
|   | AFCM          | 140570 | GEN  | ਾਧ ਸ   | v   | 3 | 5 | Quad Precision Floating               |  |
|   | 4             | 220010 |      |        | •   | U | Ŭ | Complement.                           |  |
|   | QFCS          | 526    | MR   | FLPT   | V   | 6 | 5 | Quad Precision Floating               |  |
|   | QFDV          | 525    | MR.  | FLPT   | V   | 3 | 5 | Quad Precision Floating<br>Divide     |  |
|   | QFLD          | 520    | MR.  | FLPT   | V   | - | - | Quad Precision Floating<br>Load       |  |
|   | QFLX          | 67     | MR   | FLPT   | V   |   | - | Quad Precision Floating<br>Load Index |  |
|   | QFMP          | 524    | MR   | FLPT   | V   | 3 | 5 | Quad Precision Floating               |  |
|   | QFSB          | 523    | MR.  | FLPT   | V   | 3 | 5 | Quad Precision Floating               |  |
|   | QFST          | 521    | MR   | FLPT   | V   | - | _ | Quad Precision Floating               |  |
|   | ୟ <b>∷</b> Nଦ | 140572 | GEN  | FLPT   | V   | 3 | 5 | Quad to Integer, in Quad              |  |
|   | QIQR          | 140573 | GEN  | FLPT   | V   | 3 | 5 | Quad to Integer, in Quad              |  |
|   | RBQ           | 141715 | AP   | QUEUE  | V   | - | 7 | Remove Entry from Bottom of           |  |
|   | RCB           | 140200 | GEN  | KEYS   | SRV | 8 |   | Reset CRIT to O                       |  |
| R | RMC           | 000021 | GEN  | TNTGY  | SRV | _ |   | Reset Machine Check Flag              |  |
|   |               | 000081 |      |        |     |   |   | to 0                                  |  |
|   | RRST          | 000717 | AP   | MCTT,  | v   | _ | _ | Restore Registers                     |  |
|   | RSAV          | 000715 | AP   | MCTT   | v   | _ | _ | Save Registers                        |  |
|   | RTO           | 141714 | AP   | QUEUE  | v   | _ | 7 | Remove Entry from Top of              |  |
|   |               |        |      | 4-2-2  | ·   |   | • | Queue                                 |  |
| R | RTS           | 000511 | GEN  | MCTL   | v   |   | - | Reset Time Slice                      |  |
|   | SIA           | 140110 | GEN  | INT    | SRV | 2 | 1 | Subtract 1 from A                     |  |
|   | S2A           | 140310 | GEN  | INT    | SRV | 2 | 1 | Subtract 2 from A                     |  |
|   | SAR           | 10026X | GEN  | SKIP   | SRV | _ | _ | Skip on A Register Bit Reset          |  |
|   |               |        |      |        |     |   |   | to O                                  |  |
|   | SAS           | 10126X | GEN  | SKIP   | SRV | - | - | Skip on A Register Bit Set<br>to 1    |  |
|   | SBL           | 07 03  | MR   | INT    | V   | 2 | 1 | Subtract Long                         |  |
|   | SCB           | 140600 | GEN  | KEYS   | SRV | 5 | _ | Set CBIT to 1                         |  |
|   | SGL           | 000005 | GEN  | INT    | SR  | _ | - | Enter Single Precision Mode           |  |
|   | SGT           | 100220 | GEN  | SKIP   | SRV | _ | - | Skip on A Greater Than O              |  |
|   | SKP           | 100000 | GEN  | SKIP   | SRV | - | _ | Skip                                  |  |
| R | SKS           | 34     | PIO  | IO     | SR  | _ |   | Skip on Condition Satisfied           |  |

| R | Mnem   | Opcode | Form     | Func   | М       | С | $\infty$ | Description                       |
|---|--------|--------|----------|--------|---------|---|----------|-----------------------------------|
|   | SLE    | 101220 | GEN      | SKIP   | SRV     | _ | _        | Skip on A Less Than or Equal      |
|   | SLN    | 101100 | GEN      | SKTP   | SRV     | _ | _        | Skip on ISB of A Nonzero          |
|   | ST 2   | 100100 | GEN      | SKTP   | SRV     | _ | _        | Skip on LSB of A Zero             |
|   | SMCR   | 100200 | GEN      | TNTGY  | SRV     | _ | _        | Skip on Machine Check Reset       |
|   |        | 100000 | Circlet  | 11.101 | 2       |   |          | to 0                              |
|   | SMCS   | 101200 | GEN      | INIGY  | SRV     | - |          | Skip on Machine Check Set<br>to 1 |
|   | SMI    | 101400 | GEN      | SKIP   | SRV     |   | -        | Skip on A Minus                   |
|   | SNZ    | 101040 | GEN      | SKIP   | SRV     | _ | _        | Skip on A Nonzero                 |
|   | SPL    | 100400 | GEN      | SKIP   | SRV     | _ | -        | Skip on A Plus                    |
|   | SRC    | 100001 | GEN      | SKIP   | SRV     | _ | -        | Skip on CBIT Reset to O           |
|   | SSC    | 101001 | GEN      | SKIP   | SRV     |   | _        | Skip on CBIT Set to 1             |
|   | SSM    | 140500 | GEN      | INT    | SRV     | - | _        | Set Sign of A Minus               |
|   | SSP    | 140100 | GEN      | INT    | SRV     |   | _        | Set Sign of A Plus                |
|   | SSSN   | 040310 | GEN      | MCIL   | V       | 6 | 5        | Store System Serial Number        |
|   | STA    | 04     | MR       | MOVE   | SRV     | _ | _        | Store A into Memory               |
|   | STAC   | 001200 | AP       | MOVE   | V       | _ | 7        | Store A Conditionally             |
|   | STC 0  | 001322 | CHAR     | CHAR   | v       | _ | 7        | Store Character                   |
|   | STC 1  | 001332 | CHAR     | CHAR   | v       | _ | 7        | Store Character                   |
|   | STEX   | 001315 | GEN      | PCTT   | v       | 6 | 5        | Stack Extend                      |
|   |        | 001320 |          | FTELD  | v       | _ | -        | Store FAR 0                       |
|   | STEA 1 | 001330 | ΔD       | CLEATE | v       | _ | _        | Store FAR 1                       |
|   | STIL I | 04 03  | MD       | MULTER | v       | _ | _        | Store Long                        |
|   | SIT    | 001004 |          | MONT   | V<br>V7 |   | 7        | Store L Conditionally             |
| ъ | STTC   |        | AF<br>MD | MOVE   | v<br>17 |   | י<br>ה   | Store I into Addroggod            |
| r | DITIK  | 05 01  | MIR      | MOVE   | v       | - | 0        | Register                          |
| R | STPM   | 000024 | GEN      | MCIL   | V       | - | -        | Store Processor Model Number      |
|   | STIM   | 000510 | GEN      | MCTL   | V       | 6 | 5        | Store Process Timer               |
|   | STX    | 15     | MR       | MOVE   | SRV     | - | -        | Store X                           |
|   | STY    | 35 02  | MR       | MOVE   | V       | - | -        | Store Y                           |
|   | SUB    | 07     | MR       | INT    | SRV     | 2 | 1        | Subtract                          |
|   | SVC    | 000505 | GEN      | PCILJ  | SRV     | - | -        | Supervisor Call                   |
|   | SZE    | 100040 | GEN      | SKIP   | SRV     | - | -        | Skip on A Zero                    |
|   | TAB    | 140314 | GEN      | MOVE   | V       | _ | -        | Transfer A to B                   |
|   | TAK    | 001015 | GEN      | KEYS   | V       | 7 | 6        | Transfer A to Keys                |
|   | TAX    | 140504 | GEN      | MOVE   | V       | - | -        | Transfer A to X                   |
|   | TAY    | 140505 | GEN      | MOVE   | V       | _ | _        | Transfer A to Y                   |
|   | TBA    | 140604 | GEN      | MOVE   | V       | _ | _        | Transfer B to A                   |
|   | TCA    | 140407 | GEN      | INT    | SRV     | 2 | 1        | Two's Complement A                |
|   | TCL    | 141210 | GEN      | INT    | V       | 2 | 1        | Two's Complement Long             |
|   | TFLL O | 001323 | GEN      | FIELD  | v       | _ | _        | Transfer FLR 0 to L               |
|   | TFLL 1 | 001333 | GEN      | FIELD  | v       | _ | _        | Transfer FIR 1 to L               |
|   | TKA    | 001005 | GEN      | KEYS   | v       | _ | _        | Transfer Kevs to A                |
|   | TLFL O | 001321 | GEN      | FIFID  | v       | _ | _        | Transfer L to FIR O               |
|   | TLFL 1 | 001331 | GEN      | FIFID  | v       | _ | _        | Transfer I, to FIR 1              |
|   | TSTO   | 141757 | AP       | ALLAN  | v       | _ | 7        | Test Queue                        |
|   |        |        |          | 40000  | •       |   | •        |                                   |

~ ~

\_\_\_\_\_

| R | Mnem            | Opcode | Form | Func  | M   | С | œ | Description                                     |
|---|-----------------|--------|------|-------|-----|---|---|-------------------------------------------------|
|   | TXA             | 141034 | GEN  | MOVE  | V   | _ | _ | Transfer X to A                                 |
|   | TYA             | 141124 | GEN  | MOVE  | V   | - | — | Transfer Y to A                                 |
| R | WATT            | 000315 | AP   | PRCEX | V   | - | - | Wait                                            |
|   | XAD             | 001100 | DECI | DECI  | V   | З | 1 | Decimal Add                                     |
|   | XBID            | 001145 | DECI | DECI  | V   | З | 5 | Binary to Decimal Conversion                    |
|   | XCA             | 140104 | GEN  | MOVE  | SRV | _ | - | Exchange and Clear A                            |
|   | XCB             | 140204 | GEN  | MOVE  | SRV | - | - | Exchange and Clear B                            |
|   | XCM             | 001102 | DECI | DECI  | V   | _ | 1 | Decimal Compare                                 |
|   | XDTB            | 001146 | DECI | DECI  | V   | З | 5 | Decimal to Binary Conversion                    |
|   | XDV             | 001107 | DECI | DECI  | V   | З | 5 | Decimal Divide                                  |
|   | XEC             | 01 02  | MR   | PCTLJ | RV  | - | - | Execute                                         |
|   | XED             | 001112 | DECI | DECI  | V   | - | - | Numeric Edit                                    |
|   | XMP             | 001104 | DECI | DECI  | V   | З | 1 | Decimal Multiply                                |
|   | XMV             | 001101 | DECI | DECI  | V   | 3 | 1 | Decimal Move                                    |
|   | ZCM             | 001117 | CHAR | CHAR  | V   | 6 | 7 | Compare Character Field                         |
|   | ZED             | 001111 | CHAR | CHAR  | V   | _ |   | Character Field Edit                            |
|   | $\mathbf{ZFIL}$ | 001116 | CHAR | CHAR  | V   | 6 | 5 | Fill Field With Character                       |
|   | ZMV             | 001114 | CHAR | CHAR  | V   | 6 | 5 | Move Character Field                            |
|   | ZMVD            | 001115 | CHAR | CHAR  | V   | 6 | 5 | Move Characters Between<br>Equal Length Strings |
|   | ZTRN            | 001110 | CHAR | CHAR  | V   | - | _ | Character String Translate                      |

|   |      | Table C-2   |         |
|---|------|-------------|---------|
| Ι | Mode | Instruction | Summary |

| R | Mnem   | Opcode | RI | Form | Func  | С | œ | Description                         |
|---|--------|--------|----|------|-------|---|---|-------------------------------------|
|   | A      | 02     | RI | MRGR | INT   | 2 | 1 | Add Fullword                        |
|   | ABQ    | 134    |    | AP   | QUEUE | _ | 7 | Add Entry to Bottom of Queue        |
|   | ACP    | 55     | RI | GR.  | CPTR  | _ | - | Add C Pointer                       |
|   | ADLR   | 014    |    | RGEN | INT   | 2 | 1 | Add LINK to R                       |
|   | AH     | 12     | RI | MRGR | INT   | 2 | 1 | Add Halfword                        |
|   | AIP    | 75     |    | MRGR | GRR   | 2 | 1 | Add Indirect Pointer                |
|   | ARFA O | 161    |    | RGEN | FIELD | — | - | Add R to FAR O                      |
|   | ARFA 1 | 171    |    | RGEN | FIELD | _ | - | Add R to FAR 1                      |
|   | ARGT   | 000605 |    | GEN  | PCTLJ | 6 | 5 | Argument Transfer                   |
|   | ATQ    | 135    |    | AP   | QUEUE | - | 7 | Add Entry to Top of Queue           |
|   | BCEQ   | 141602 |    | BRAN | BRAN  | - | - | Branch on Condition Code EQ         |
|   | BOGE   | 141605 |    | BRAN | BRAN  | - | - | Branch on Condition Code GE         |
|   | BOGT   | 141601 |    | BRAN | BRAN  | - | - | Branch on Condition Code GT         |
|   | BCLE   | 141600 |    | BRAN | BRAN  | - | - | Branch on Condition Code LE         |
|   | BCLT   | 141604 |    | BRAN | BRAN  | - | - | Branch on Condition Code LT         |
|   | BCNE   | 141603 |    | BRAN | BRAN  | - | - | Branch on Condition Code NE         |
|   | BCR    | 141705 |    | BRAN | BRAN  | - | - | Branch on CBIT Reset to O           |
|   | BCS    | 141704 |    | BRAN | BRAN  | - | - | Branch on CBIT Set to 1             |
|   | BFEQ   | 122    |    | IBRN | BRAN  | - | 4 | Branch on F Equal to O              |
|   | BFGE   | 125    |    | IBRN | BRAN  |   | 4 | Branch on F Greater Than or         |
|   |        |        |    |      |       |   |   | Equal to O                          |
|   | BFGT   | 121    |    | IBRN | BRAN  |   | 4 | Branch on F Greater Than 0          |
|   | BFLE   | 120    |    | IBRN | BRAN  | _ | 4 | Branch on F Less Than or            |
|   |        |        |    |      |       |   |   | Equal to O                          |
|   | BFLT   | 124    |    | IBRN | BRAN  | _ | 4 | Branch on F Less Than O             |
|   | BFNE   | 123    |    | IBRN | BRAN  | - | 4 | Branch on F Not Equal to 0          |
|   | BHD1   | 144    |    | IBRN | BRAN  | — | - | Branch on r Decremented by 1        |
|   | BHD2   | 145    |    | IBRN | BRAN  | _ | - | Branch on r Decremented by 2        |
|   | BHD4   | 146    |    | IBRA | BRAN  | _ | - | Branch on r Decremented by 4        |
|   | BHEQ   | 112    |    | IBRN | BRAN  | - | 4 | Branch on r Equal to O              |
|   | BHGE   | 115    |    | IBRN | BRAN  | - | 4 | Branch on r Greater Than or         |
|   |        |        |    |      |       |   |   | Equal to O                          |
|   | BHGT   | 111    |    | IBRN | BRAN  |   | 4 | Branch on r Greater Than O          |
|   | BHI1   | 140    |    | IBRN | BRAN  | - | - | Branch on r Incremented by 1        |
|   | BHI3   | 141    |    | IBRN | BRAN  | _ | - | Branch on r Incremented by 2        |
|   | BHI4   | 142    |    | IBRN | BRAN  | — | - | Branch on r Incremented by 4        |
|   | BHLE   | 110    |    | IBRN | BRAN  | - | 4 | Branch on r Less Than or            |
|   |        |        |    |      |       |   |   | Equal to O                          |
|   | BHLT   | 114    |    | IBRN | BRAN  | - | 4 | Branch on r Less Than O             |
|   | BHINE  | 113    |    | IBRN | BRAN  | - | 4 | Branch on r Not Equal to O          |
|   | BLR    | 141707 |    | BRAN | BRAN  | - | - | Branch on LINK Reset to O           |
|   | BLS    | 141706 |    | BRAN | BRAN  | - | - | Branch on LINK Set to 1             |
|   | BMEQ   | 141602 |    | BRAN | BRAN  | - | - | Branch on Magnitude Condition       |
|   | BMGE   | 141706 |    | BRAN | BRAN  | - |   | Branch on Magnitude Condition<br>GE |
|   |        |        |    |      |       |   |   |                                     |

| R | Mnem | Opcode  | RI       | Form  | Func          | C | œ      | Description                            |
|---|------|---------|----------|-------|---------------|---|--------|----------------------------------------|
|   | BMGT | 141710  |          | BRAN  | BRAN          | - | -      | Branch on Magnitude Condition GT       |
|   | BMLE | 141711  |          | BRAN  | BRAN          | - | _      | Branch on Magnitude Condition<br>LE    |
|   | BMLT | 141707  |          | BRAN  | BRAN          | - | -      | Branch on Magnitude Condition          |
|   | BMNE | 141603  |          | BRAN  | BRAN          | - | _      | Branch on Magnitude Condition NE       |
|   | BRBR | 040-077 | ,        | IBRN  | BRAN          | _ | -      | Branch on Register Bit Reset<br>to O   |
|   | BRBS | 000-037 |          | IBRN  | BRAN          | - | -      | Branch on Register Bit Set<br>to 1     |
|   | BRD1 | 134     |          | IBRN  | BRAN          | - | -      | Branch on R Decremented by 1           |
|   | BRD2 | 135     |          | IBRN  | BRAN          | _ | -      | Branch on R Decremented by 1           |
|   | BRD4 | 136     |          | IBRN  | BRAN          |   |        | Branch on R Decremented by 4           |
|   | BREQ | 102     |          | IBRN  | BRAN          |   | 4      | Branch on R Equal to 0                 |
|   | BRGE | 105     |          | IBRN  | BRAN          | _ | 4      | Branch on R Greater Than or            |
|   |      |         |          |       |               |   |        | Equal to O                             |
|   | BRGT | 101     |          | IBRN  | BRAN          | _ | 4      | Branch on R Greater Than 0             |
|   | BRI1 | 130     |          | IBRN  | BRAN          | _ | -      | Branch on R Incremented by 1           |
|   | BRI2 | 131     |          | IBRN  | BRAN          | _ | _      | Branch on R Incremented by 2           |
|   | BRI4 | 132     |          | IBRN  | BRAN          | _ | -      | Branch on R Incremented by 4           |
|   | BRLE | 100     |          | IBRN  | BRAN          | - | 4      | Branch on R Less Than or<br>Equal to 0 |
|   | BRLT | 104     |          | IBRN  | BRAN          | _ | 4      | Branch on R Less Than O                |
|   | BRNE | 103     |          | IBRN  | BRAN          | _ | 4      | Branch on R Not Equal to O             |
|   | С    | 61      | RI       | MRGR  | INT           | 1 | 1      | Compare Fullword                       |
|   | CALF | 000705  |          | AP    | PCILJ         | 6 | 5      | Call Fault Handler                     |
|   | CCP  | 45      | R        | GR    | CPTR          | _ | 1      | Compare C Pointer                      |
|   | OGT  | 026     |          | RGEN  | BRAN          | 6 | 5      | Computed GOTO                          |
|   | CH   | 71      | RI       | MRGR  | INT           | ī | 1      | Compare Halfword                       |
|   | CHS  | 040     |          | RGEN  | INT           | _ | _      | Change Sign                            |
|   | CMH  | 045     |          | RGEN  | LOGIC         | _ | _      | Complement r                           |
|   | CMR  | 044     |          | RGEN  | LOGIC         | _ | _      | Complement R                           |
|   | CR   | 056     |          | RGEN  | CLEAR         | _ | _      | Clear R to O                           |
|   | CRBL | 062     |          | RGEN  | CLEAR         | _ | _      | Clear R High Byte 1 Right              |
|   | CRBR | 063     |          | RGEN  | CLEAR         | _ | _      | Clear R High Byte 2 Right              |
|   | CRHI | 054     |          | RGEN  | CLEAR         | _ | _      | Clear R Left Halfword                  |
|   | CRHR | 055     |          | RGEN  | CLEAR         | _ | _      | Clear R Right Halfword                 |
|   | CSR  | 041     |          | RGEN  | MOVE          | 5 | _      | Copy Sign of R                         |
|   | D    | 62      | RT       | MRCR  | INT           | 3 | 5      | Divide Fullword                        |
|   | DBLE | 106     |          | RGEN  | गपग           | _ | _      | Convert Single to Double               |
|   |      | 160     |          | DCENT |               |   |        | Precision Floating                     |
|   |      |         | ът       | MDER  | OPIK<br>DI DI | 7 | -      | Double Procision Floating Add          |
|   | DEC  | 15,17   | KL<br>DT | MRFR  | LT DO         | З | 0<br>1 | Double Precision Floating Add          |
|   | Uru: | 05,07   | ĸT       | MKFK  | LTLI          | - | T      | Compare                                |

| R      | Mnem        | Opcode      | RI | Form | Func  | С | C        | Description                             |
|--------|-------------|-------------|----|------|-------|---|----------|-----------------------------------------|
|        | DFCM        | 144         |    | RGEN | FLPT  | 3 | 5        | Double Precision Floating<br>Complement |
|        | DFD         | 31,33       | RI | MRFR | FLPT  | 3 | 5        | Double Precision Floating<br>Divide     |
|        | DFL         | 01,03       | RI | MRFR | FLPT  | - | -        | Double Precision Floating<br>Load       |
|        | DFM         | 25,27       | RI | MRFR | FLPT  | 3 | 5        | Double Precision Floating<br>Multiply   |
|        | DFS         | 21.23       | RI | MRFR | FLPT  | 3 | 5        | Double Precision Floating<br>Subtract   |
|        | DFST        | 11,13       |    | MRFR | FLPT  | - | -        | Double Precision Floating<br>Store      |
|        | DH          | 72          | RI | MRGR | INT   | 3 | 5        | Divide Halfword                         |
|        | DH1         | 130         |    | RGEN | INT   | 2 | 1        | Decrement r by 1                        |
|        | DH2         | 131         |    | RGEN | INT   | 2 | 1        | Decrement r by 2                        |
|        | DM          | 60          |    | MRNR | INT   | — | l        | Decrement Memory Fullword               |
|        | DMH         | 70          |    | MRNR | INT   | - | 1        | Decrement Memory Halfword               |
|        | DR1         | 124         |    | RGEN | INT   | 2 | 1        | Decrement R by 1                        |
|        | DR2         | 125         |    | RGEN | INT   | 2 | 1        | Decrement R by 2                        |
|        | DRN         | 040300      |    | GEN  | FLPT  | 3 | 5        | Double Round From Quad                  |
|        | DRNM        | 140571      |    | GEN  | FLPT  | 8 | 5        | Double Round From Quad                  |
|        |             |             |    |      |       |   |          | Towards Negative Infinity               |
|        | DRNP        | 040301      |    | GEN  | FLPT  | З | 5        | Double Round From Quad                  |
|        |             |             |    |      |       | _ | _        | Towards Positive Infinity               |
|        | DRNZ        | 040302      |    | GEN  | FLPT  | 3 | 5        | Double Round From Quad                  |
|        |             |             |    |      |       |   |          | Towards Zero                            |
|        | E16S        | 000011      |    | GEN  | ADMOD | - | -        | Enter 16S Mode                          |
|        | E32I        | 001010      |    | GEN  | ADMOD | _ | -        | Enter 321 Mode                          |
|        | E32R        | 001013      |    | GEN  | ADMOD | - | -        | Enter 32R Mode                          |
|        | E32S        | 000013      |    | GEN  | ADMOD | - | _        | Enter 325 Mode                          |
|        | E64R        | 001011      |    | GEN  | ADMOD | - | -        | Enter 64R Mode                          |
|        | EO4V        |             |    | GEN  |       | _ | -        | Enter 64V Mode                          |
|        | EAFA U      | 001500      |    | AP   | FIED  | - | -        | Effective Address to FAR U              |
|        | EAFA 1      | 40          |    | AP   | FIELD | _ | -        | Effective Address to FAR I              |
|        | EAD         | 42<br>67    |    | MOCD |       | _ | _        | Effective Address to LD                 |
|        | EAR         | 00<br>60    |    | MOND | POILD | - | -        | Effective Address to R                  |
| D      | EAAD<br>ETO | 020<br>73.4 |    | MDCD | TO    | _ | - 7      | Ellective Address to AB                 |
| л<br>D | ETO         |             |    | CEN  | TO    | _ | <u> </u> | Enable Interments                       |
| R      | ENBL.       | 000401      |    | GEN  | TO    | _ | _        | Enable Intermints (Local)               |
| R      | ENBM        | 000400      |    | GEN  | TO    | _ | _        | Enable Intermints (Mutual)              |
| R      | ENBP        | 000402      |    | GEN  | TO    | _ | _        | Enable Intermints (Process)             |
| - V    | FA          | 014.16      | RT | MRFR | ਾਧ, ਇ | з | 5        | Floating Add                            |
|        | FC          | 04.06       | RT | MRFR | FLPT  | _ | 1        | Floating Compare                        |
|        | FCDO        | 140571      |    | GEN  | FLPT  | _ | -        | Floating Convert Double to              |
|        | EVIN        | 100         |    |      |       | 7 | F        | Quad                                    |
|        | run         | 100         |    | RUTH | LTTL. | З | Э        | rioauting complement                    |

| R | Mnem          | Opcode | RI  | Form | Func      | С | œ | Description                                           |
|---|---------------|--------|-----|------|-----------|---|---|-------------------------------------------------------|
|   | FD            | 30,32  | RI  | MRFR | FLPT      | 3 | 5 | Floating Divide                                       |
|   | $\mathbf{FL}$ | 00,02  | RI  | MRFR | FLPT      | - | - | Floating Load                                         |
|   | FLT           | 105,11 |     | RGEN | FLPT      | 6 | 5 | Convert Integer to Floating<br>Point                  |
|   | FLTH          | 102,11 |     | RGEN | FLPT      | 6 | 5 | Convert Halfword Integer to                           |
|   | FM            | 24.26  | RT  | MRFR | FLPT      | З | 5 | Floating Multiply                                     |
|   | FRN           | 107    |     | RGEN | FLPT      | 3 | 5 | Floating Round                                        |
|   | FRNM          | 146    |     | RGEN | FLPT      | 3 | 5 | Floating Round Towards                                |
|   | FRNP          | 145    |     | RGEN | FLPT      | 3 | 5 | Floating Round Towards<br>Positive Infinity           |
|   | FRNZ          | 147    |     | RGEN | गप.ान     | 3 | 5 | Floating Round Towards Zero                           |
|   | FS            | 50 55  | ЪL  | MRFR | ידים. דיז | 3 | 5 | Floating Subtract                                     |
|   | FST           | 1012   | 101 | MRFR | יזים. דיז | 3 | 5 | Floating Store                                        |
| R | HI T          | 10,10  |     | GEN  | MCTT.     | - | - | Halt.                                                 |
|   | I             | 41     | R   | MRGR | MOVE      | - | - | Interchange R and Memory<br>Fullword                  |
|   | ICBL          | 065    |     | RGEN | MOVE      | - | - | Interchange Bytes and Clear<br>Left                   |
|   | ICBR          | 066    |     | RGEN | MOVE      | - | - | Interchange Bytes and Clear<br>Right                  |
|   | ICHL          | 060    |     | RGEN | MOVE      | - |   | Interchange Halfwords and<br>Clear Left               |
|   | ICHR          | 061    |     | RGEN | MOVE      | - | - | Interchange Halfwords and<br>Clear Right              |
|   | ICP           | 167    |     | RGEN | CPIR      | - | - | Increment C Pointer                                   |
|   | IH            | 51     | R   | MRGR | MOVE      | - | _ | Interchange r and and Memory<br>Halfword              |
|   | IHl           | 126    |     | RGEN | INT       | 2 | 1 | Increment r by 1                                      |
|   | IH2           | 127    |     | RGEN | INT       | 2 | 1 | Increment r by 2                                      |
|   | IM            | 40     |     | MRNR | INT       | _ | 1 | Increment Memory Fullword                             |
|   | IMH           | 50     |     | MRNR | INT       | _ | 1 | Increment Memory Halfword                             |
| R | INBC          | 001217 |     | AP   | PRCEX     | 6 | 5 | Interrupt Notify Beginning,<br>Clear Active Interrupt |
| R | INBN          | 001215 |     | AP   | PRCEX     | 6 | 5 | Interrupt Notify Beginning                            |
| R | INEC          | 001216 |     | AP   | PRCEX     | 6 | 5 | Interrupt Notify End, Clear<br>Active Interrupt       |
| R | INEN          | 001214 |     | AP   | PRCEX     | 6 | 5 | Interrupt Notify End                                  |
| R | INH           | 001001 |     | GEN  | IO        | - | _ | Inhibit Interrupts                                    |
| R | INHL          | 001001 |     | GEN  | IO        | - |   | Inhibit Interrupts (Local)                            |
| R | INHM          | 001000 |     | GEN  | IO        | - |   | Inhibit Interrupts (Mutual)                           |
| R | INHP          | 001002 |     | GEN  | IO        | - |   | Inhibit Interrupts (Process)                          |
|   | INK           | 070    |     | RGEN | KEYS      | - |   | Input Keys                                            |
|   | INT           | 103,11 |     | RGEN | FLPT      | 3 | 5 | Convert Floating Point to                             |
|   |               |        |     |      |           |   |   | Integer                                               |

\_\_\_\_\_

| R<br> | Mnem   | Opcode | RI | Form | Func  | _C | œ | Description                                   |  |  |  |
|-------|--------|--------|----|------|-------|----|---|-----------------------------------------------|--|--|--|
|       | INTH   | 101,11 |    | RGEN | FLPT  | 3  | 5 | Convert Floating Point to<br>Halfword Integer |  |  |  |
|       | IR1    | 122    |    | RGEN | INT   | 2  | 1 | Increment R by 1                              |  |  |  |
|       | IR2    | 123    |    | RGEN | INT   | 2  | 1 | Increment R by 2                              |  |  |  |
|       | IRB    | 064    |    | RGEN | MOVE  | _  | _ | Interchange r Bytes                           |  |  |  |
|       | IRH    | 057    |    | RGEN | MOVE  | _  | - | Interchange R Halves                          |  |  |  |
| R     | IRTC   | 000603 |    | GEN  | IO    | 7  | 6 | Interrupt Return, Clear                       |  |  |  |
|       |        |        |    |      |       | ·  | - | Active Interrupt                              |  |  |  |
| R     | IRIN   | 000601 |    | GEN  | IO    | 7  | 6 | Interrupt Return                              |  |  |  |
| R     | ITLB   | 000615 |    | GEN  | MCIL  | 6  | 5 | Invalidate STLB Entry                         |  |  |  |
|       | JMP    | 51     |    | MRNR | PCILJ | -  | _ | Jump                                          |  |  |  |
|       | JSR    | 73     |    | MRGR | PCILJ | -  | - | Jump to Subroutine                            |  |  |  |
|       | JSXB   | 61     |    | MRNR | PCTLJ | _  | _ | Jump and Save in XB                           |  |  |  |
|       | L      | 01     | RI | MRGR | MOVE  | _  |   | Load                                          |  |  |  |
|       | LCC    | 45     |    | MRGR | CPTR  | _  | 7 | Load C Character                              |  |  |  |
|       | LCEQ   | 153    |    | RGEN | LTSTS | _  | _ | Load r on Condition Code EQ                   |  |  |  |
|       | LOGE   | 154    |    | RGEN | LTSTS | _  | - | Load r on Condition Code GE                   |  |  |  |
|       | LOGT   | 155    |    | RGEN | LTSTS | -  | _ | Load r on Condition Code GT                   |  |  |  |
|       | LCLE   | 151    |    | RGEN | LTSTS | -  | - | Load r on Condition Code LE                   |  |  |  |
|       | LCLT   | 150    |    | RGEN | LTSTS | _  | _ | Load r on Condition Code LT                   |  |  |  |
|       | LCNE   | 152    |    | RGEN | LTSTS | _  | _ | Load r on Condition Code NE                   |  |  |  |
| P     | LDAR   | 44     |    | MRGR | MOVE  | _  | 5 | Load from Addressed Register                  |  |  |  |
|       | LDC 0  | 162    |    | RGEN | CHAR  | _  | 7 | Load Character                                |  |  |  |
|       | LDC 1  | 172    |    | RGEN | CHAR  | _  | 7 | Load Character                                |  |  |  |
|       | LEQ    | 003    |    | RGEN | LTSTS | _  | 4 | Load r on R Equal to O                        |  |  |  |
|       | LF     | 016    |    | RGEN | LTSTS | -  | 5 | Load False                                    |  |  |  |
|       | LFEQ   | 023,03 |    | RGEN | LTSTS | _  | 4 | Load r on F Equal to O                        |  |  |  |
|       | LFGE   | 024,03 |    | RGEN | LTSTS | -  | 4 | Load r on F Greater Than or                   |  |  |  |
|       |        |        |    |      |       |    |   | Equal to 0                                    |  |  |  |
|       | LFGT   | 025,03 |    | RGEN | LTSTS | _  | 4 | Load r on F Greater Than O                    |  |  |  |
|       | LFLE   | 021,03 |    | RGEN | LTSTS | _  | 4 | Load r on F Less Than or                      |  |  |  |
|       |        |        |    |      |       |    |   | Equal to 0                                    |  |  |  |
|       | LFLI O | 001303 |    | BRAN | FIELD | _  | - | Load FLR 0 Immediate                          |  |  |  |
|       | LFLI 1 | 001313 |    | BRAN | FIELD |    | - | Load FLR 1 Immediate                          |  |  |  |
|       | LFLT   | 020,03 |    | RGEN | LTSTS | _  | 4 | Load r on F Less Than O                       |  |  |  |
|       | LFNE   | 022,03 |    | RGEN | LTSTS | _  | 4 | Load r on F Not Equal to O                    |  |  |  |
|       | LGE    | 004    |    | RGEN | LTSTS | —  | 4 | Load r on R Greater Than or                   |  |  |  |
|       |        |        |    |      |       |    |   | Equal to O                                    |  |  |  |
|       | LGT    | 005    |    | RGEN | LTSTS | -  | 4 | Load r on R Greater Than O                    |  |  |  |
|       | LH     | 11     | RI | MRGR | MOVE  | _  | - | Load Halfword                                 |  |  |  |
|       | THEO   | 013    |    | RGEN | LTSTS | -  | 4 | Load r on r Equal to O                        |  |  |  |
|       | LHGE   | 004    |    | RGEN | LTSTS | -  | 4 | Load r on r Greater Than or                   |  |  |  |
|       |        |        |    |      |       |    |   | Equal to O                                    |  |  |  |
|       | LHGT   | 015    |    | RGEN | LTSTS | -  | 4 | Load r on r Greater Than O                    |  |  |  |
|       | LHL1   | 04     | R  | MRGR | MOVE  | -  | - | Load Halfword Shifted Left                    |  |  |  |
|       |        |        |    |      |       |    |   | by 1                                          |  |  |  |
|       |        |        |    |      |       |    |   |                                               |  |  |  |

# Table C-2 (continued) I Mode Instruction Summary

~

r

| R | Mnem | Opcode | RI | Form | Func            | С | œ | Description                            |
|---|------|--------|----|------|-----------------|---|---|----------------------------------------|
|   | LHL2 | 14     | R  | MRGR | MOVE            |   |   | Load Halfword Shifted Left<br>by 2     |
|   | LHL3 | 35     | R  | MRGR | MOVE            | - | - | Load Halfword Shifted Left<br>by 3     |
|   | LHLE | 011    |    | RGEN | LTSTS           | _ | 4 | Load r on r Less Than or<br>Equal to 0 |
|   | LHLT | 000    |    | RGEN | LTSTS           | _ | 4 | Load r on r Less Than O                |
|   | LHNE | 012    |    | RGEN | LTSTS           | _ | 4 | Load r on r Not Equal to O             |
| R | LIOT | 000044 |    | AP   | MCTL            | 6 | 5 | Load IOILB                             |
|   | LIP  | 65     |    | MRGR | GRR             | _ | _ | Load Indirect Pointer                  |
|   | LLE  | 001    |    | RGEN | LTSTS           | - | 4 | Load r on R Less Than or<br>Equal to 0 |
|   | LLT  | 000    |    | RGEN | LTSTS           | _ | 4 | Load r on R Less Than O                |
|   | LNE  | 200    |    | RGEN | LTSTS           | _ | 4 | Load r on R Not Equal to O             |
| R | LPID | 000617 |    | GEN  | MCIL            | _ | - | Load Process ID                        |
| R | LPSW | 000711 |    | AP   | MCTL            | 7 | 6 | Load Process Status Word               |
|   | LT   | 017    |    | RGEN | LTSTS           | - | 5 | Load True                              |
|   | М    | 42     | RI | MRGR | INT             | * | _ | Multiply Fullword                      |
|   | MH   | 52     | RI | MRGR | INT             | З | 5 | Multiply Halfword                      |
|   | N    | 03     | RI | MRGR | LOGIC           | _ | _ | AND Fullword                           |
| R | NFYB | 001211 |    | AP   | PRCEX           | 6 | 5 | Notify                                 |
| R | NFYE | 001210 |    | AP   | PRCEX           | 6 | 5 | Notify                                 |
|   | NH   | 13     | RI | MRGR | LOGIC           | _ | - | AND Halfword                           |
|   | NOP  | 000001 |    | GEN  | MCIL            | - | _ | No Operation                           |
|   | 0    | 23     | RI | MRGR | LOGIC           | _ | _ | OR Fullword                            |
|   | OH   | 33     | RI | MRGR | LOGIC           | _ | - | OR Halfword                            |
|   | OTK  | 071    |    | RGEN | KEYS            | 7 | 6 | Output Keys                            |
|   | PCL  | 41     |    | MRNR | PCILJ           | 6 | 5 | Procedure Call                         |
|   | PID  | 052    |    | RGEN | INT             | - | - | Position for Integer Divide            |
|   | PIDH | 053    |    | RGEN | INT             | - | - | Position r for Integer<br>Divide       |
|   | PIM  | 050    |    | RGEN | INT             | 3 | 5 | Position after Multiply                |
|   | PIMH | 051    |    | RGEN | INT             | 3 | 5 | Position r after Multiply              |
|   | PRIN | 000611 |    | GEN  | PCILJ           | 7 | 6 | Procedure Return                       |
| R | PILB | 000064 |    | GEN  | MCTL            | 6 | 5 | Purge TLB                              |
|   | QFAD | 36     |    | MRFR | FLPT            | 3 | 5 | Quad Precision Floating Add            |
|   | QFC  | 47     | RI | MRFR | FLPT            | - | 7 | Quad Precision Floating<br>Compare     |
|   | QFCM | 140570 |    | GEN  | FLPT            | 3 | 5 | Quad Precision Floating<br>Complement  |
|   | QFDV | 46     |    | MRFR | FLPT            | 3 | 5 | Quad Precision Floating<br>Divide      |
|   | QFLD | 34     |    | MRFR | $\mathbf{FLPT}$ | - | - | Quad Precision Floating Load           |
|   | QFMP | 45     |    | MRFR | FLPT            | 3 | 5 | Quad Precision Floating<br>Multiply    |
|   | QFSB | 37     |    | MRFR | FLPT            | 3 | 5 | Quad Precision Floating<br>Subtract    |

| R | Mnem          | Opcode | RI | Form | Func  | С | œ | Description                                 |
|---|---------------|--------|----|------|-------|---|---|---------------------------------------------|
|   | QFST          | 35     |    | MRFR | FLPT  | _ | _ | Quad Precision Floating Store               |
|   | QINQ          | 140572 |    | GEN  | FLPT  | 3 | 5 | Quad to Integer, in Quad<br>Convert         |
|   | QIQR          | 140573 |    | GEN  | FLPT  | 3 | 5 | Quad to Integer, in Quad<br>Convert Rounded |
|   | RBQ           | 133    |    | AP   | QUEUE | - | 7 | Remove Entry from Bottom<br>of Queue        |
|   | RCB           | 140200 |    | GEN  | KEYS  | 8 | - | Reset CBIT to O                             |
| R | RMC           | 000021 |    | GEN  | INIGY | _ | - | Reset Machine Check Flag to O               |
|   | ROT           | 24     |    | MRGR | SHIFT | 4 | - | Rotate                                      |
|   | RRST          | 000717 |    | AP   | MCTL  | - | - | Restore Registers                           |
|   | RSAV          | 000715 |    | AP   | MCTL  | _ | - | Save Registers                              |
|   | RTQ           | 132    |    | RGEN | QUEUE | - | 7 | Remove Entry from Top of                    |
|   | •             |        |    |      | •     |   |   | Queue                                       |
| R | RTS           | 000511 |    | GEN  | MCTL  | _ | - | Reset Time Slice                            |
|   | S             | 22     | RI | MRGR | INT   | 2 | 1 | Subtract Fullword                           |
|   | SCB           | 140600 |    | GEN  | KEYS  | 5 | - | Set CBIT to 1                               |
|   | SOC           | 55     |    | MRGR | CPIR  |   | - | Store C Character                           |
|   | SH            | 32     | RI | MRGR | INT   | 2 | 1 | Subtract Halfword                           |
|   | SHA           | 15     |    | MRGR | SHIFT | 4 | _ | Shift Arithmetic                            |
|   | SHL           | 05     |    | MRGR | SHIFT | 4 | - | Shift Logical                               |
|   | SHL1          | 076    |    | RGEN | SHIFT | 4 | _ | Shift R Left 1                              |
|   | SHL2          | 077    |    | RGEN | SHIFT | 4 | _ | Shift R Left 2                              |
|   | SHR1          | 120    |    | RGEN | SHIFT | 4 | - | Shift R Right 1                             |
|   | SHR2          | 121    |    | RGEN | SHIFT | 4 | _ | Shift R Right 2                             |
|   | SL1           | 072    |    | RGEN | SHIFT | 4 | _ | Shift R Left 1                              |
|   | SL2           | 073    |    | RGEN | SHIFT | 4 | _ | Shift R Left 2                              |
|   | SR1           | 074    |    | RGEN | SHIFT | 4 | _ | Shift R Right 1                             |
|   | SR2           | 075    |    | RGEN | SHIFT | 4 | _ | Shift R Right 2                             |
|   | SSM           | 042    |    | RGEN | INT   | _ |   | Set Sign Minus                              |
|   | SSP           | 043    |    | RGEN | INT   | _ | _ | Set Sign Plus                               |
|   | SSSN          | 040310 |    | GEN  | MCTL  | 6 | 5 | Store System Serial Number                  |
|   | $\mathbf{ST}$ | 21     |    | MRGR | MOVE  | _ | _ | Store Fullword                              |
| Ρ | STAR          | 54     |    | MRGR | MOVE  | _ | 5 | Store into Addressed Register               |
|   | STC 0         | 166    |    | RGEN | CHAR  |   | 7 | Store Character                             |
|   | STC 1         | 176    |    | RGEN | CHAR  | - | 7 | Store Character                             |
|   | STCD          | 137    |    | AP   | MOVE  | - | 7 | Store Conditional Fullword                  |
|   | STCH          | 136    |    | AP   | MOVE  | _ | 7 | Store Conditional Halfword                  |
|   | STEX          | 027    |    | RGEN | PCILJ | 6 | 5 | Stack Extend                                |
|   | STFA O        | 001320 |    | AP   | FIELD | _ | _ | Store FAR O                                 |
|   | STFA 1        | 001330 |    | AP   | FIELD | _ | _ | Store FAR 1                                 |
|   | STH           | 31     |    | MRGR | MOVE  | _ | _ | Store Halfword                              |
| R | STPM          | 000024 |    | GEN  | MCTL  |   | _ | Store Processor Model Number                |
|   | STIM          | 000510 |    | GEN  | MCTL  | 6 | 5 | Store Process Timer                         |
|   | SVC           | 000505 |    | GEN  | PCTLJ | _ | _ | Supervisor Call                             |
|   | TC            | 046    |    | RGEN | INT   | 3 | 1 | Two's Complement R                          |
|   | TCH           | 047    |    | RGEN | INT   | 3 | 1 | Two's Complement r                          |
|   |               |        |    |      |       |   |   | -                                           |

r

| R | Mnem   | Opcode | RI | Form | Func  | С | œ | Description                                     |
|---|--------|--------|----|------|-------|---|---|-------------------------------------------------|
|   | TCNP   | 76     | R  | MRNR | CPTR  | _ | 1 | Test C Null Pointer                             |
|   | TFLR O | 163    |    | RGEN | FIELD | _ | - | Transfer FLR 0 to R                             |
|   | TFIR 1 | 173    |    | RGEN | FIELD | - |   | Transfer FLR 1 to R                             |
|   | TM     | 44     |    | MRNR | MCTL  | - | 1 | Test Memory Fullword                            |
|   | TMH    | 54     |    | MRNR | INT   | _ | 1 | Test Memory Halfword                            |
|   | TRFL O | 165    |    | RGEN | FIELD | - | - | Transfer R to FIR O                             |
|   | TRFL 1 | 175    |    | RGEN | FIELD | - | - | Transfer R to FLR 1                             |
|   | TSTQ   | 104    |    | RGEN | QUEUE | - | 7 | Test Queue                                      |
| R | WAIT   | 000315 |    | AP   | PRCEX | — | - | Wait                                            |
|   | X      | 43     | RI | MRGR | LOGIC |   | - | Exclusive OR Fullword                           |
|   | XAD    | 001100 |    | DECI | DECI  | 3 | 1 | Decimal Add                                     |
|   | XBID   | 001145 |    | DECI | DECI  | 3 | 5 | Binary to Decimal Conversion                    |
|   | XCM    | 001102 |    | DECI | DECI  | - | 1 | Decimal Compare                                 |
|   | XDTB   | 001146 |    | DECI | DECI  | 3 | 5 | Decimal to Binary Conversion                    |
|   | XDV    | 001107 |    | DECI | DECI  | 3 | 5 | Decimal Divide                                  |
|   | XED    | 001112 |    | DECI | DECI  | - | - | Numeric Edit                                    |
|   | XH     | 53     | RI | MRGR | LOGIC |   | - | Exclusive OR Halfword                           |
|   | XMP    | 001104 |    | DECI | DECI  | 3 | 1 | Decimal Multiply                                |
|   | XMV    | 001101 |    | DECI | DECI  | 3 | 1 | Decimal Move                                    |
|   | ZCM    | 001117 |    | CHAR | CHAR  | 6 | 7 | Compare Character Field                         |
|   | ZED    | 001111 |    | CHAR | CHAR  | - | - | Character Field Edit                            |
|   | ZFIL   | 001116 |    | CHAR | CHAR  | 6 | 5 | Fill Field With Character                       |
|   | ZM     | 43     |    | MRNR | CLEAR |   | - | Clear Fullword                                  |
|   | ZMH    | 53     |    | MRNR | CLEAR |   | - | Clear Halfword                                  |
|   | ZMV    | 001114 |    | CHAR | CHAR  | 6 | 5 | Move Character Field                            |
|   | ZMVD   | 001115 |    | CHAR | CHAR  | 6 | 5 | Move Characters Between Equal<br>Length Strings |
|   | ZTRN   | 001110 |    | CHAR | CHAR  |   | - | Character String Translate                      |

# D Hardware Consideration in Performance

Several hardware considerations have bearing on performance. First, some instructions execute faster than others. To identify these, this document lists the relative instruction weights for V and I modes. Special note is made of preferred load/store, arithmetic, and bulk data move instructions for optimum execution times. Second, the type of address formation also affects execution times. To identify these, this appendix shows the relative weights of different address formations; the performance penalties for unaligned data, cache miss, STLB miss, and address traps are also shown. Recommendations are given for how to use all of this information when coding in PMA or a high level language.

Performance of emitted code or assembler coding of identified time-crucial routines requires some knowledge of instruction execution times. Prime has never given these out before for many reasons:

- Prime's 50 Series Processors are an entire line of machines that have differing performances.
- The execution time of an instruction is based on many events such as addressing mode and data alignment, making this a complex issue.
- Contractual guarantees based on published times are certain to be wrong because of the previous point.
- There is a bad correlation of instruction times to MIPs in fact, but not in the minds of the press. Hence we would mislead by giving specific times.

Having said that, nevertheless, tuners must tune. The following tables represent relative "best case" weights for the "perfect" 50 Series machine. No actual machine has exactly this balance, but the 6350 and 9955 II come close.

#### INSTRUCTION WEIGHTS

To use these tables, locate the desired mnemonic and note its weight in units. The following abbreviations are used.

- A -- Equal to 0 if there are no PCL arguments. Equal to 8+6\*n where n is the number of arguments.
- D -- The number of destination digits.
- N -- In shift instructions, the number of shifts to perform. In decimal and character instructions, the number of digits or characters involved.
- S -- The number of source digits.
- # -- The number of non-zero destination digits.

| AlA       1       ELS       3       EAFA       3       INTA       14         AEQ       20       EMEQ       2       EAL       1       IES       3         ACA       1       EMCE       2       EALB       2       IENTC       9         ACD       1       EMCE       2       EALB       2       IENTC       9         ADD       1       EMCE       2       EALB       1       IES       3         ADL       1       EMCE       3       EAXB       1       IETN       4         ADL       1       EMCE       2       EAB       3       JMP       2       1         ALL       1       EMCE       2       ERA       1       JSST       7         ALR       N+2       EMME       3       ESIM       4       JSST       5         ANL       1       CAL       R       PCM       6       LOGT       2       1         ARR       N+2       CAS       4       PFCS       6       LOGT       2       1       1       1       1         BC3Q       2       CAA       1       FLD                                                                                                                                                         | Mnem   | Units      | 1 Mnem | Units  | 1 Mnem | Units    | Mnem   | Units      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|--------|--------|--------|----------|--------|------------|
| $ \begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        | 1          | BLS    | 3      | E64V   | 8        |        | 14         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | A2A    | ī          | BLT    | 3      | EAFA   | 3        | INTL   | 14         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ABO    | 2 <u>0</u> | BMEQ   | 2      | EAL    | 1        | IRS    | 3          |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        | 1          | BMGE   | 2      | EALB   | 2        | IRTC   | 9 1        |
| ATL       1       EWCT       3       EUO       12       IRX       2       1         ALL       1       EMLE       3       ENCM       4       ITLB       8         ALL       N+2       EMLE       2       ERA       1       JST       7         ALL       N+2       EMME       3       ESL       1       JST       7         ALL       N+2       EMME       3       ESL       1       JST       7         ALL       N+2       EME       3       ESL       1       JST       7         ALL       N+2       EAL       1       JST       7       1         ANA       1       CAL       EVTM       4       JST       5         ANL       1       CAL       EVTM       4       JST       5         ARL       N+2       CAR       1       FDEL       1       LCE2       1         ARR       N+2       CAZ       3       FDEL       1       LCLE       1         ARR       N+2       CAR       1       FITA       10       LDL       1         BCEQ       CHS       1       FITA </td <td></td> <td>ī</td> <td>BMGT</td> <td>3</td> <td>EAXB</td> <td>ĩ</td> <td>TRIN</td> <td>4 1</td>                                                |        | ī          | BMGT   | 3      | EAXB   | ĩ        | TRIN   | 4 1        |
| ADIL       1       EMCH       4       ITTLB       8       1         ALFA       2       EMLT       2       ENE       3       JMP       2         ALL       N+2       EMME       2       ERE       1       JSX       5       1         ALR       N+2       EME       3       ESIM       4       JSXE       5       1         ALS       N+2       CAI       3       ESIM       4       JSXE       5       1         ALS       N+2       CAI       3       ESIM       4       JSXE       5       1         ANA       1       CAL       1       EVIM       4       JSXE       5       1         ARCT       See       FCL       CAR       1       FVM       4       JSXE       5         ARGT       See       FCL       CAR       1       FVD       4       ICIP       2       1         ARS       N+2       CAS       4       FID       2       ICME       2       1         ARS       N+2       CAS       1       FID       2       ICME       2       1         BCD       20                                                                                                                                                     | ADT    | 1          | BMGT   | 3      | ETO    | 12       | TRX    | 2          |
| ALPA       2       EMET       2       EME       3       JMP       2       1         ALL       N+2       EMME       2       ERA       1       JST       7       1         ALR       N+2       EME       3       ERL       1       JST       5       1         ALS       N+2       EAL       1       ESTM       4       JST       5       1         ANA       1       CAL       1       ESTM       4       JST       5       1         ANA       1       CAL       1       ESTM       4       JST       5       1         ARG       N+2       CAR       1       FCD       4       LCGE       2       1         ARR       N+2       CAS       3       FDEL       1       LCLE       2       1         ARS       N+2       CAS       3       FDEL       1       LCLE       2       1         ARS       N+2       CAS       1       FLTA       10       LDL       1       1         BCEQ       2       CRA       1       FLTA       10       LDL       1       1         BCER                                                                                                                                                      | ADLT.  | 1          | BMLE   | 3      | EMCM   | 4        | TTTB   | 8 1        |
| ALL       N+2       EMAL       2       ERA       1       JST       7       1         ALR       N+2       CAI       3       ESL       1       JSX       5       1         ALS       N+2       CAI       3       ESLM       4       JSXB       5       1         ANA       1       CALF       63       FAD       4       JSX       5       1         ANL       1       CALF       63       FAD       4       JSXB       5       1         ARL       N+2       CAR       1       FCM       6       LCEP       2       1         ARR       N+2       CAS       4       FCS       6       LCIF       2       1         ARS       N+2       COT       9       FDV       38       LCIF       2       1         BCEP       2       CRA       1       FILT       15       LDC       10       1         BCEE       2       CRA       1       FILT       15       LDC       10       1         BCEP       2       CRA       1       FRM       1       LDL       1       1         B                                                                                                                                                      | ATFA   | 2          | BMIJ   | 2      |        | 3        | I      | 2 1        |
| ALR       N+2       IENE       3       IENE       1       JSX       5       1         I ALS       N+2       ICAI       3       IESIM       4       JSXB       5       1         I ALS       N+2       ICAI       3       IESIM       4       JSXB       5       1         I ANA       1       I CAL       1       IEVIM       4       JSXB       5       1         I ANL       1       I CAL       1       IEVIM       4       JSXB       5       1         I ARG       N+2       I CAR       1       IFUEL       1       ICCE       2       1         I ARR       N+2       I CAS       4       IFUEL       1       ICCE       2       1         ARS       N+2       I CAS       4       IFUEL       1       ICCE       2       1         ARS       N+2       I CAS       4       IFUEL       1       ILDE       2       1       ILDE       1       1         ARS       N+2       I CAS       1       IFUE       1       ILDE       1       1       1       1       1       1       1       1       1 <td>AT.J.</td> <td>N+2</td> <td>BMNE</td> <td>2</td> <td>ERA</td> <td>ĩ</td> <td>JST</td> <td>7</td>                   | AT.J.  | N+2        | BMNE   | 2      | ERA    | ĩ        | JST    | 7          |
| ALS       N+2       CAI       3       ESTM       4       JSXB       5       1         ANA       1       CAL       1       EVIM       4       JSXB       5       1         ANA       1       CAL       1       EVIM       4       JSXB       5       1         ARG       1       CAL       1       FVD       4       LCQQ       1         ARG       N+2       CAR       1       FCM       6       LCQE       2         ARR       N+2       CAZ       3       FDEL       1       LCLE       2       1         ARR       N+2       CAZ       3       FDEL       1       LCLE       2       1         ARS       N+2       COT       9       FDV       38       LCLT       2       1         BCE       2       CRA       1       FLT       10       LDA       1       1         BCR       2       CRA       1       FTM       14       LDX       1       1         BCR       2       CRL       1       FRM       7       LDY       1       1         BCR       2       CRL <td></td> <td>N+2</td> <td>BNE</td> <td>ã</td> <td>ERI</td> <td>ī</td> <td>JSX</td> <td>5 1</td>                                                        |        | N+2        | BNE    | ã      | ERI    | ī        | JSX    | 5 1        |
| ANA       1       CAL       1       EVIN       4       JSE       5       1         ANL       1       CALF       63       FAD       4       JSE       5       1         ANL       1       CALF       63       FAD       4       JSE       5       1         ARL       N+2       CAS       4       FCS       6       LOET       2       1         ARR       N+2       CAS       3       FDEL       1       LOEE       2       1         ARS       N+2       CAS       1       FLD       2       LONE       2       1         BCEQ       2       CHS       1       FLD       1       LOEN       2       1         BCEQ       2       CRA       1       FLT       15       LDC       10       1         BCET       2       CRA       1       FLT       15       LDC       10       1         BCET       2       CRE       1       FRN       14       LDR       1       1         BCET       2       CRE       1       FRN       14       LDR       1         BCET       2 <td>ATS</td> <td>N+2</td> <td></td> <td>3</td> <td>ESTM</td> <td>4</td> <td>JSXB</td> <td>5 1</td>                                                      | ATS    | N+2        |        | 3      | ESTM   | 4        | JSXB   | 5 1        |
| ANL       1       I CALF       63       I FAL       1       I CEQ       2       I         ARCT       See PCL       I CAR       1       I FOM       6       I LOEQ       2       I         ARL       N+2       I CAS       4       I FOS       6       I LOET       2       I         ARR       N+2       I CAZ       3       I FDEL       1       I LOE       2       I         ARS       N+2       I CAZ       3       I FDEL       1       I LOE       2       I         ARS       N+2       I CAZ       3       I FDEL       1       I LOE       2       I         ARS       N+2       I CAZ       3       I FDEL       1       I LOE       2       I         ARS       N+2       I CAZ       3       I FITL       15       I LOC       10       1         BCEE       2       I CRA       1       I FITX       1       I LIC       1       1         BCIE       2       I CRA       1       I FRN       14       I LDZ       1       1         BCIE       2       I CRE       2       I FRN       14       I LDZ </td <td></td> <td>1</td> <td></td> <td>ĩ</td> <td>EVTM</td> <td>4</td> <td>JSY</td> <td>5 1</td>         |        | 1          |        | ĩ      | EVTM   | 4        | JSY    | 5 1        |
| ARGT       See       PCL       CAR       1       FRD       1       ICM       5         I ARL       N+2       I CAS       4       I FCS       6       I LOGT       2       I         I ARR       N+2       I CAS       4       I FCS       6       I LOCE       2       I         I ARR       N+2       I CAS       4       I FDV       38       I LILE       2       I         I ARS       N+2       I CAS       4       I FID       2       I LILE       2       I         I ARS       N+2       I CAS       4       I FID       2       I LILE       2       I         I ARG       20       I CHS       1       I FID       2       I LOE       2       I         I BCE       2       I CKA       1       I FIT       10       I LD       1       I         I BCE       2       I CRA       1       I FRN       14       I LDX       1       I         I BCE       2       I CRA       1       I FRN       14       I LDX       1       I         I BCE       2       I CRA       1       I FRN       14       I L                                                                                                          | ANT.   | 1          |        | 63     |        | 4        |        | 2 1        |
| ARL       N+2       I CAR       I       I CAR       I       I CAR       I CAR       I       I CAR       I I CAR       I I I I I I I I I I I I I I I I I I I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        | See PCT.   |        | 1      | I FYM  | Ē        |        | 2          |
| ARB       N+2       ICAS       4       ICBL       1       ICLE       2         I ARR       N+2       ICCT       9       IFDEL       1       ICLE       2       1         I ARS       N+2       ICCT       9       IFDEL       1       ICLE       2       1         I ARS       N+2       ICCS       4       IFDEL       1       ICLE       2       1         I BCEQ       2       ICCS       4       IFDA       10       IDA       1       1         I BCGE       2       ICCRA       1       IFIX       1       IDIC       10       1         I BCLE       2       ICRA       1       IFIX       1       IDIC       1       1         I BCLE       2       ICRA       1       IFIN       14       IDIX       1       1         I BCR       2       ICRE       1       IFRN       14       IDIX       1       1         I BCR       2       ICRE       2       IFRN       11       IEQ       3       1         I BCR       3       IDFAD       6       IFSE       4       IIFEQ       4       1 </td <td></td> <td>NTO<br/>NTO</td> <td></td> <td>1<br/>A</td> <td>FOR</td> <td>6</td> <td></td> <td>2</td>                   |        | NTO<br>NTO |        | 1<br>A | FOR    | 6        |        | 2          |
| ARX       N+2 $OCT$ 9 $FDD$ 38 $ICDT$ 2         ARS       N+2 $OCT$ 9 $FDV$ 38 $ICDT$ 2         BCEQ       2 $CLS$ 4 $FDD$ 2 $ICNE$ 2         BCEQ       2 $CLS$ 4 $FDT$ 10 $IDA$ 1         BCEZ       2 $CRA$ 1 $FDT$ 15 $IDL$ 1         BCEZ       2 $CRA$ 1 $FDP$ 9 $IDL$ 1       1         BCEZ       2 $CRE$ 1 $FMP$ 9 $IDL$ 1       1         BCEZ       2 $CRE$ 1 $FMP$ 9 $IDL$ 1       1         BCR       2 $CRE$ 1 $FRN$ 14 $IDY$ 1       1         BCR       2 $CRL$ 1 $FRN$ 14 $IDY$ 1       1         BCR       2 $CSA$ 1 $FRN$ 14 $IEF$ 1       1         BEQ       3       <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |        | NTS<br>NLO |        | 7      |        | 1        |        | 2 I        |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        | N+S<br>N+O |        | 0      |        | 1<br>70  |        | 2          |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | S TAT      |        | 3      |        | <i>.</i> |        |            |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | I DOBO | 20         |        | 1      |        | چ<br>١0  |        |            |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | DUDY   | 2          |        | 1<br>1 |        | 10       |        |            |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | ະ<br>ເ     |        | 1      |        | 15       |        | 10 1       |
| I BCLE         2         I CRB         1         I FMP         9         I LLR         11         1           I BCLT         2         I CRE         1         I FRN         14         I LDX         1         I           I BCNE         2         I CRL         1         I FRNM         7         I LDY         1         I           I BCR         2         I CRLE         2         I FRNM         7         I LDY         1         I           I BCR         2         I CRLE         2         I FRNM         7         I LDY         1         I           I BCR         2         I CRLE         2         I FRNM         7         I LDY         1         I         I EQ         3         I         I FRM         14         I LFEQ         4         I           I BDX         3         I DFCM         6         I FSCT         4         I LFGT         4         I           I BFGE         3         I DFLX         2         I FSNT         3         I LFLT         4         I           I BFGE         3         I DFST         5         I HLT         0         I LGE         3         I           |        | 2          |        | 1      |        | 1        |        |            |
| BCHT         2         CRE         1         FRN         14         I LDK         1           BCNE         2         CRL         1         FRNM         7         I LDY         1           BCR         2         CRLE         2         FRNP         11         I LEQ         3           BCS         2         CRA         1         FRNZ         12         I.F         2           BDX         3         DFAD         6         FSB         4         I LFQQ         4           BDY         3         DFCM         6         FSGT         4         I LFGE         4           BEQ         3         DFCS         8         FSLE         4         I LFGT         4           BFEQ         3         DFLX         2         FSNZ         4         I LFLE         4           BFGT         3         DFLX         2         FSNZ         4         I LFT         4           BFLE         3         DFSB         6         FSZE         4         I LGT         3           BFT         3         DFN         14         I CA         1         I LIGT         3           BCT<                                          |        | 2          |        | 1      |        | 9        |        | 11 1       |
| I BCRE       2       I CRL       1       I FRNM       7       I LDY       1         I BCR       2       I CRLE       2       I FRNP       11       I LEQ       3       I         I BCS       2       I CRA       1       I FRNZ       12       I LF       2       I         I BDX       3       I DFAD       6       I FSB       4       I LFQQ       4       I         I BDY       3       I DFOM       6       I FSGT       4       I LFQQ       4       I         I BDY       3       I DFOM       6       I FSGT       4       I LFQQ       4       I         I BEQ       3       I DFON       38       I FSMI       4       I LFLE       4       I         I BFGT       3       I DFLD       2       I FSNZ       4       I LFLI       2       I         I BFGT       3       I DFSB       6       I FSZE       4       I LGE       3       I         I BFNE       3       I DFST       5       I HLT       0       I LGT       3       I         I BGE       3       I DRN       14       I CA       1       I LLEQ                                                                                                     | BULL   | 2          |        | Ţ      | FRN    | 14       |        |            |
| I BCR       2       I CRLE       2       I FRNP       11       I LEQ       3       I         I BCS       2       I CSA       1       I FRNZ       12       I LF       2       I         I BDX       3       I DFAD       6       I FSB       4       I LFQQ       4       I         I BDX       3       I DFAD       6       I FSB       4       I LFQQ       4       I         I BDX       3       I DFAD       6       I FSB       4       I LFQQ       4       I         I BDX       3       I DFCM       6       I FSB       4       I LFQQ       4       I         I BFQQ       3       I DFCN       38       I FSMI       4       I LFLE       4       I         I BFGT       3       I DFLX       2       I FSNZ       4       I LFLI       4       I         I BFGT       3       I DFSF       6       I FSZE       4       I LGE       3       I         I BFNE       3       I DFN       14       I CA       1       I LLEQ       1       I         I BGE       3       I DFN       14       I CA       1                                                                                                           | BONE   | 2          |        | 1      | FRNM   |          |        |            |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | BCR    | 2          |        | 2      | FRNP   | 11       |        | 3 1        |
| HELX       3         DFAD       6         FSB       4         LFEQ       4         HEDY       3         DFCM       6         FSGT       4         LFGE       4           BEQ       3         DFCS       8         FSLE       4         LFGT       4           BFGQ       3         DFDV       38         FSMI       4         LFLE       4           BFGE       3         DFLD       2         FSNZ       4         LFLF       4           BFGE       3         DFLX       2         FSNZ       4         LFLT       4           BFGT       3         DFMP       15         FST       3         LFNE       4           BFLE       3         DFSB       6         FSZE       4         LGE       3           BFNE       3         DFN       5         HLT       0         LGT       3                   BGE       3         DRN       14         ICA       1         LLE       3                   BIX       3         DRN       14         ICA       1         LLEQ       3                   BIX       3         DRNZ                                                                                                        | BCS    | 2          | CSA    | 1      | FRNZ   | 12       | 1 TT.  | 2          |
| HDY       3       I DFCM       6       I FSGT       4       I LFGE       4         I BEQ       3       I DFCS       8       I FSLE       4       I LFGT       4         I BFEQ       3       I DFDV       38       I FSMI       4       I LFGT       4         I BFGE       3       I DFDV       38       I FSMI       4       I LFLE       4         I BFGE       3       I DFLD       2       I FSMZ       4       I LFLI       2         I BFGE       3       I DFLX       2       I FST       3       I LFNE       4       I         I BFLE       3       I DFMP       15       I FST       3       I LFNE       4       I         I BFLE       3       I DFSB       6       I FSZE       4       I LGE       3         I BGE       3       I DFN       5       I HLT       0       I LGT       37       I         BGE       3       I DRN       14       I ICA       1       I LEQ       3       I         BEX       3       I DRN       14       I ICA       1       I LEQ       3       I         BIX       3 </td <td>BDX</td> <td>3</td> <td>DFAD</td> <td>6</td> <td>FSB</td> <td>4</td> <td>LFEQ</td> <td>4  </td> | BDX    | 3          | DFAD   | 6      | FSB    | 4        | LFEQ   | 4          |
| I       BEQ       3       I       DFCS       8       I       FSLE       4       I       LFGT       4       I         I       BFEQ       3       I       DFDV       38       I       FSMI       4       I       LFLE       4       I         I       BFGE       3       I       DFLD       2       I       FSNZ       4       I       LFLI       2       I         I       BFGT       3       I       DFMP       15       I       FST       3       I       LFNE       4       I         I       BFLE       3       I       DFMP       15       I       FST       3       I       LFNE       4       I         I       BFLE       3       I       DFSB       6       I       FSZE       4       I       LGE       3       I         I       BGE       3       I       DFST       5       I       HLT       O       I       GT       37       I         BGE       3       I       DRN       14       I       ICA       1       I       LLEQ       3       I         BIX       3 </td <td>BDY</td> <td>3</td> <td>DFCM</td> <td>6</td> <td>FSGT</td> <td>4</td> <td>LFGE</td> <td>4</td>                                         | BDY    | 3          | DFCM   | 6      | FSGT   | 4        | LFGE   | 4          |
| I       BFEQ       3       I       DFDV       38       I       FSMI       4       I       LFLE       4       I         I       BFGE       3       I       DFLD       2       I       FSNZ       4       I       LFLI       2       I         I       BFGT       3       I       DFLX       2       I       FSNZ       4       I       LFLI       2       I         I       BFGT       3       I       DFLX       2       I       FSNZ       4       I       LFLI       4       I         I       BFLE       3       I       DFSB       6       I       FSZE       4       I       IGE       3       I         I       BFNE       3       I       DFST       5       I       HLT       0       I       IGT       3       I         I       BGE       3       I       DRN       10       I       ICA       1       I       LLEQ       3       I         I       BIX       3       I       DRN       10       I       ICR       1       I       LLEQ       3       I         I <td>BEQ</td> <td>3</td> <td>DFCS</td> <td>8</td> <td>  FSLE</td> <td>4</td> <td>  LFGT</td> <td>4  </td>                                          | BEQ    | 3          | DFCS   | 8      | FSLE   | 4        | LFGT   | 4          |
| I       BFGE       3       I       DFLD       2       I       FSNZ       4       I       LFLI       2       I         I       BFGT       3       I       DFLX       2       I       FSPL       4       I       LFLT       4       I         I       BFLE       3       I       DFMP       15       I       FST       3       I       LFNE       4       I         I       BFLE       3       I       DFSB       6       I       FSZE       4       I       GE       3       I         I       BFNE       3       I       DFST       5       I       HLT       0       I       GT       3       I         I       BGE       3       I       DFN       14       I       ICA       1       I       LLE       3       I         I       BGT       3       I       DRN       14       I       ICA       1       I       LLEQ       3       I         I       BIX       3       I       DRN       5       I       ICIC       1       I       LLEQ       3       I         I                                                                                                                                                         | BFEQ   | 3          | I DFDV | 38     | FSMI   | 4        | I LFLE | 4 I        |
| I       BFGT       3       I       DFLX       2       I       FSPL       4       I       LFTT       4       I         I       BFLE       3       I       DFMP       15       I       FST       3       I       LFNE       4       I         I       BFLT       3       I       DFSB       6       I       FSZE       4       I       LGE       3       I         I       BFNE       3       I       DFST       5       I       HLT       0       I       LGT       3       I         I       BGE       3       I       DRN       14       I       ICA       1       I       LLE       3       I         I       BGT       3       I       DRN       14       I       ICA       1       I       LLEQ       3       I         I       BIX       3       I       DRN       5       I       ICL       1       I       LLEQ       3       I         I       BLE       3       I       DRN       9       I       ILE       3       I       LLGT       3       I         I                                                                                                                                                           | BFGE   | 3          | I DFLD | 2      | FSNZ   | 4        | IFLI   | 2          |
| I       BFLE       3       I       DFMP       15       I       FST       3       I       LFNE       4       I         I       BFLT       3       I       DFSB       6       I       FSZE       4       I       LGE       3       I         I       BFNE       3       I       DFST       5       I       HLT       0       I       LGT       3       I         I       BGE       3       I       DIV       20       I       IAB       2       I       LIOT       377       I         I       BGE       3       I       DRN       14       I       ICA       1       I       LLE       3       I         I       BIX       3       I       DRN       5       I       ICL       1       I       LLEQ       3       I         I       BLX       3       I       DRNZ       9       I       ILE       3       I       LGT       3       I         I       BLEQ       3       I       DRX       2       I       IMA       4       I       ILL       N+2       I         I                                                                                                                                                          | BFGT   | 3          | DFLX   | 2      | FSPL   | 4        | I LFLT | <b>4</b> I |
| I       BFLT       3       I       DFSB       6       I       FSZE       4       I       IGE       3       I         I       BFNE       3       I       DFST       5       I       HLT       0       I       IGT       3       I         I       BGE       3       I       DIV       20       I       IAB       2       I       LIOT       37       I         I       BGE       3       I       DRN       14       I       ICA       1       I       LIE       3       I         I       BIX       3       I       DRN       14       I       ICA       1       I       LIEQ       3       I         I       BIX       3       I       DRN       5       I       ICL       1       I       LIEQ       3       I         I       BIX       3       I       DRNZ       9       I       ILE       3       I       LICT       3       I         I       BLEQ       3       I       DRX       2       I       IMA       4       I       ILL       N+2       I         I       <                                                                                                                                                    | BFLE   | 3          | I DFMP | 15     | I FST  | 3        | I LFNE | <b>4</b> I |
| I       BFNE       3       I       DFST       5       I       HLT       0       I       LGT       3       I         I       BGE       3       I       DIV       20       I       IAB       2       I       LIOT       37       I         I       BGT       3       I       DRN       14       I       ICA       1       I       LIE       3       I         I       BIX       3       I       DRN       14       I       ICA       1       I       LIE       3       I         I       BIX       3       I       DRN       5       I       ICL       1       I       LIEQ       3       I         I       BIX       3       I       DRNP       10       I       ICR       1       I       LIEQ       3       I         I       BLE       3       I       DRNZ       9       I       ILE       3       I       LICT       3       I         I       BLEQ       3       I       DRX       2       I       IMA       4       I       LL       N+2       I         I <td< td=""><td>BFLT</td><td>3</td><td>I DFSB</td><td>6</td><td>I FSZE</td><td>4</td><td>I LGE</td><td><b>3</b> I</td></td<>                                  | BFLT   | 3          | I DFSB | 6      | I FSZE | 4        | I LGE  | <b>3</b> I |
| I       BGE       3       I       DIV       20       I       IAB       2       I       LIOT       37       I         I       BGT       3       I       DRN       14       I       ICA       1       I       LIDT       37       I         I       BIX       3       I       DRN       14       I       ICA       1       I       LIE       3       I         I       BIX       3       I       DRN       5       I       ICL       1       I       LIEQ       3       I         I       BIY       3       I       DRNP       10       I       ICR       1       I       LIEQ       3       I         I       BLE       3       I       DRNZ       9       I       ILE       3       I       LICT       3       I         I       BLEQ       3       I       DRX       2       I       IMA       4       I       LIL       N+2       I         I       BLEQ       3       I       DVL       47       I       INBC       40       I       LILE       3       I         I                                                                                                                                                        | BFNE   | 3          | DFST   | 5      | I HLT  | 0        | LGT    | 3          |
| I       BGT       3       I       DRN       14       I       ICA       1       I       ILE       3       I         I       BIX       3       I       DRNM       5       I       ICL       1       I       ILEQ       3       I         I       BIY       3       I       DRNP       10       I       ICR       1       I       ILEQ       3       I         I       BLE       3       I       DRNZ       9       I       ILE       3       I       ILGT       3       I         I       BLEQ       3       I       DRX       2       I       IMA       4       I       ILL       N+2       I         I       BLEQ       3       I       DVL       27       I       INBC       40       I       ILL       N+2       I         I       BLGE       3       I       DVL       47       I       INBC       40       I       ILL       N+2       I         I       BLGE       3       I       E32I       8       I       INEC       40       I       ILL       3       I       IL       I <td>BGE</td> <td>3</td> <td>I DIV</td> <td>20</td> <td>IAB</td> <td>2</td> <td>LIOT</td> <td>37  </td>                                    | BGE    | 3          | I DIV  | 20     | IAB    | 2        | LIOT   | 37         |
| I       BIX       3       I       DRNM       5       I       ICL       1       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I       I<                                                                                                                                     | BGT    | 3          | I DRN  | 14     | I ICA  | 1        | I LIE  | <b>3</b> I |
| I       BIY       3       I       DRNP       10       I       ICR       1       I       ILGE       3       I         I       BLE       3       I       DRNZ       9       I       ILE       3       I       LIGT       3       I         I       BLEQ       3       I       DRX       2       I       IMA       4       I       ILL       N+2       I         I       BLEQ       3       I       DVL       2       I       IMA       4       I       ILL       N+2       I         I       BLGE       3       I       DVL       47       I       INBC       40       I       ILLE       3       I         I       BLET       3       I       E321       8       I       INEC       40       I       ILLE       3       I         I       BLLT       3       I       E32R       8       I       INEN       35       I       ILLR       N+2       I         I       BLNE       3       I       E32S       8       I       INH       3       I       ILS       N+2       I <td< td=""><td>BIX</td><td>3</td><td>I DRNM</td><td>5</td><td>ICL</td><td>1</td><td>I TTEO</td><td><b>3</b>  </td></td<>                              | BIX    | 3          | I DRNM | 5      | ICL    | 1        | I TTEO | <b>3</b>   |
| I       BLE       3       I       DRNZ       9       I       ILE       3       I       LIGT       3       I         I       BLEQ       3       I       DRX       2       I       IMA       4       I       LL       N+2       I         I       BLGE       3       I       DVL       47       I       INBC       40       I       LLE       3       I         I       BLGE       3       I       DVL       47       I       INBC       40       I       LLE       3       I         I       BLGT       3       I       E16S       8       I       INEN       35       I       LLLT       3       I         I       BLLE       3       I       E32R       8       I       INEN       35       I       LLR       N+2       I         I       BLNE       3       I       E32S       8       I       INH       3       I       LLS       N+2       I         I       BLR       3       I       E64R       8       I       INK       6       I       LT       3       I                                                                                                                                                            | BIY    | 3          | I DRNP | 10     | I ICR  | 1        | LIGE   | 3          |
| I       BLEQ       3       I       DRX       2       I       IMA       4       I       ILL       N+2       I         I       BLGE       3       I       DVL       47       I       INBC       40       I       ILLE       3       I         I       BLGT       3       I       E16S       8       I       INBC       40       I       ILLE       3       I         I       BLLE       3       I       E32I       8       I       INEC       40       I       ILLE       3       I         I       BLLE       3       I       E32I       8       I       INEC       40       I       ILNE       3       I         I       BLLT       3       I       E32R       8       I       INEN       35       I       ILR       N+2       I         I       BLNE       3       I       E32S       8       I       INH       3       I       LLS       N+2       I         I       BLR       3       I       E64R       8       I       INK       6       I       ILT       3       I <td>BLE</td> <td>3</td> <td>DRNZ</td> <td>9</td> <td>ILE</td> <td>3</td> <td>LIGT</td> <td><b>3</b> I</td>                                          | BLE    | 3          | DRNZ   | 9      | ILE    | 3        | LIGT   | <b>3</b> I |
| I       BLGE       3       I       DVL       47       I       INBC       40       I       LLE       3       I         I       BLGT       3       I       E16S       8       I       INBN       35       I       ILLE       3       I         I       BLLE       3       I       E32I       8       I       INEC       40       I       LLE       3       I         I       BLLE       3       I       E32I       8       I       INEC       40       I       LINE       3       I         I       BLLT       3       I       E32R       8       I       INEN       35       I       LIR       N+2       I         I       BLNE       3       I       E32S       8       I       INH       3       I       LLS       N+2       I         I       BLR       3       I       E64R       8       I       INK       6       I       LIT       3       I                                                                                                                                                                                                                                                                            | BLEQ   | 3          | DRX    | 2      | IMA    | 4        | III    | N+2 !      |
| I       BLGT       3       I       E16S       8       I       INEN       35       I       LLT       3       I         I       BLLE       3       I       E32I       8       I       INEC       40       I       LINE       3       I         I       BLLT       3       I       E32R       8       I       INEN       35       I       LLR       N+2       I         I       BLNE       3       I       E32S       8       I       INH       3       I       LLS       N+2       I         I       BLR       3       I       E64R       8       I       INK       6       I       LLT       3       I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | BLGE   | 3          | I DVL  | 47     | INBC   | 40       | ILLE   | <b>3</b> I |
| BLLE 3   E32I 8   INEC 40   LLNE 3  <br>  BLLT 3   E32R 8   INEN 35   LLR N+2  <br>  BLNE 3   E32S 8   INH 3   LLS N+2  <br>  BLR 3   E64R 8   INK 6   LLT 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | BLGT   | 3          | E16S   | 8      | INBN   | 35       | IIIT   | 3          |
| BLLT 3   E32R 8   INEN 35   ILR N+2  <br>  BLNE 3   E32S 8   INH 3   ILS N+2  <br>  BLR 3   E64R 8   INK 6   ILT 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | BLLE   | 3          | E32I   | 8      | I INEC | 40       | LINE   | 3          |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | BLLT   | 3          | E32R   | 8      | INEN   | 35       | ILLR   | N+2        |
| I BLR 3 I E64R 8 I INK 6 I LLT 3 I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | BLNE   | 3          | E32S   | 8      | INH    | 3        | ILLS   | N+2        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | BLR    | 3          | E64R   | 8      | INK    | 6        | I LLT  | <b>3</b> I |

Table D-1 V Mode Instruction Weights

~

\*

| Mnem   | Units       | 1 Mnem  | Units | 1 Mnem | Units |   | Mnem            | Units           |
|--------|-------------|---------|-------|--------|-------|---|-----------------|-----------------|
| LMCM   | 4           | QFST    | 19    | I SR3  | 10    | 1 | TAX             | 1               |
| I LNE  | 3           | I QIINQ | 55    | I SR4  | 10    | Ι | TAY             | 1               |
| I LPID | 6           | I QIQR  | 56    | I SRC  | 3     |   | TBA             | 1               |
| I LPSW | 14          | I RBQ   | 20    | SS1    | 10    | I | TCA             | 2               |
| I LRL  | N+2         | I RCB   | 1     | I SS2  | 10    | Ι | TCL             | 2               |
| I LRR  | N+2         | I RMC   | 15    | I SS3  | 10    | I | TFLL            | 3               |
| IRS    | N+2         | RRST    | 44    | SS4    | 10    |   | TKA             | 3               |
| LT     | 2           | I RSAV  | 85    | SSC    | 3     |   | $\mathbf{TLFL}$ | 2               |
| MPL    | 13          | I RTQ   | 18    | I SSM  | 1     | 1 | TSTQ            | 7               |
| I MPY  | 8           | I RTS   | 10    | SSP    | 1     | 1 | TXA             | 1               |
| NFYB   | 35          | S1A     | 1     | I SSR  | 10    | Ι | TYA             | 1               |
| I NFYE | 35          | I S2A   | 1     | I SSS  | 10    | Ι | WAIT            | 58              |
| I NOP  | 1           | SAR     | 3     | I SSSN | 37    | I | XAD             | 76+3*N          |
| ORA    | 1           | I SAS   | 3     | I STA  | 2     |   | XBID            | 40+5* <b>N</b>  |
| I OTK  | 9           | SBL     | 1     | STAC   | 8     |   | XCA             | 2               |
| I PCL  | <b>40+A</b> | I SCB   | 1     | STC    | 12    | I | XCB             | 2               |
| I PIDA | 2           | I SGT   | 3     | STEX   | 9     | I | XCM             | 80+2*N          |
| PIDL   | 3           | SKP     | 7     | I STFA | 8     | ł | XDTB            | 40+5* <b>N</b>  |
| PIMA   | 3           | I SLE   | 3     | I STL  | 2     | 1 | XDV             | 90+65* <b>#</b> |
| PIML   | 4           | I SLN   | 3     | I STLC | 9     | 1 | XEC             | 9               |
| PRTN   | 16          | I SLZ   | 3     | SILR   | 13    | 1 | XED             | Varies          |
| I PTLB | 400         | SMCR    | 5     | I STPM | 12    | 1 | XMP             | 88+15*S*D       |
| I QFAD | 56          | SMCS    | 5     | STIM   | 17    | I | XMV             | 80+3*N          |
| I QFCM | 10          | I SMI   | 3     | I STX  | 2     | I | ZCM             | 20+N            |
| QFCS   | 39          | I SNR   | 10    | I STY  | 2     | I | ZED             | Varies          |
| QFDV   | 489         | I SNS   | 10    | I SUB  | 1     | l | ZFIL            | 14+0.5*N        |
| QFLD   | 14          | I SNZ   | 3     | I SVC  | 36    | I | ZMV             | 18+0.75*N       |
| I QFLX | 2           | I SPL   | 3     | I SZE  | 3     | I | ZMVD            | 14+0.75*N       |
| I QFMP | 65          | I SR1   | 10    | I TAB  | 1     | I | ZTRN            | 1 <b>4+8*N</b>  |
| I QFSB | 57          | I SR2   | 10    | I TAK  | 3     | I |                 |                 |

# Table D-1 (Continued) V Mode Instruction Weights

D-4
\_\_\_\_

| i Mnem | Units   | Mnem  | Units | 1 Mnem | Units      | Mnem     | Units      |
|--------|---------|-------|-------|--------|------------|----------|------------|
| A      | 1       | BRD4  | 3     | E16S   | 8          | INT      | 14         |
| ABO    | 20      | BREQ  | 3     | E32I   | 8          | INTH     | 14         |
| ACP    | 4       | BRGE  | 3     | E32R   | 8          | IR1      | 1          |
| ADLR   | ī       | BRGT  | 3     | E32S   | 8          | IR2      | 1          |
| AH     | ī       | BRII  | 3     | E64R   | 8          | IRB      | 1          |
| AIP    | 2       | BRI2  | 3     | E64V   | 8          | IRH      | 2          |
| ARFA   | 2       | BRI4  | 3     | EAFA   | 3          | IRTC     | <b>9</b> I |
| ARGT   | See PCL | BRLE  | 3     | EALB   | 2          | IRTN     | <b>4</b> I |
| ATQ    | 20      | BRLT  | 3     | EAR    | 1          | ITLB     | <b>8</b> I |
| BCEQ   | 2       | BRNE  | 3     | EAXB   | 1          | I JMP    | 2          |
| BOGE   | 2       | C     | 1     | I EIO  | 12         | I JSR    | 5          |
| BOGT   | 2       | CAI   | 3     | EMCM   | 4          | I JSXB   | 5          |
| BCLE   | 2       | CALF  | 63    | I ENB  | 3          | <b>L</b> | 1          |
| BCLT   | 2       | OCP   | 5     | I ESIM | 4          |          | <b>3</b> I |
| BCNE   | 2       | OGT   | 9     | EVIM   | 4          | LCEQ     | 2          |
| BCR    | 2       | CH    | 1     | FA     | 4          | I LOGE   | 2          |
| BCS    | 2       | CHS   | 1     | FC     | 10         | LOGT     | 2 1        |
| BFEQ   | 3       | CMH   | 1     | FCM    | 6          | LCLE     | 2 1        |
| BFGE   | 3       | CMR   | 1     | FD     | 38         | LCLT     | 2          |
| BFGT   | 3       | CR    | 1     | FL     | 2          | I LCNE   | 2          |
| BFLE   | 3       | CRBL  | l     | I FLT  | 15         | LDAR     | 11         |
| BFLT   | 3       | CRBR  | 1     | FLTH   | 10         |          | 10         |
| BFNE   | 3       | CRHL  | 1     | I FM   | 9          | I LEQ    | <b>3</b> I |
| BHD1   | 3       | CRHR  | 1     | FRN    | 14         | LF       | 2          |
| BHD2   | 3       | CSR   | 1     | FRNM   | 7          | LFEQ     | <b>4</b> I |
| BHD4   | 3       | D     | 47    | FRNP   | 11         | I LFGE   | <b>4</b> I |
| BHEQ   | 3       | DBLE  | 1     | FRNZ   | 12         | LFGT     | <b>4</b> I |
| BHGE   | 3       | DCP   | 3     | FS     | 4          | I LFLE   | <b>4</b> I |
| BHGT   | 3       | DFA   | 6     | FST    | 3          | I LFLI   | <b>2</b> I |
| BHI1   | 3       | DFC   | 10    | HLT    | 0          | LFLT     | <b>4</b> 1 |
| BHI2   | 3       | DFCM  | 6     | II     | 4          | LFNE     | <b>4</b> I |
| BHI4   | 3       | DFD   | 38    | ICBL   | 1          | i LGE    | 3 1        |
| BHLE   | 3       | DFL   | 2     | ICBR   | 1          | LGT      | <b>3</b> I |
| BHLT   | 3       | DFM   | 15    | I ICHL | 1          | LH       | 1          |
| BHNE   | 3       | DFS   | 6     | ICHR   | 1          | I LHEQ   | <b>3</b> I |
| BLR    | 3       | DFST  | 5     | I ICP  | 3          | LHGE     | <b>3</b> I |
| I BLS  | 3       | DH    | 20    | I IH   | 4          | LHGT     | 3          |
| I BMEQ | 2       | DH1   | 1     | I IHI  | 1          | LHL1     | 1          |
| BMGE   | 2       | DH2   | 1     | IH2    | 1          | I THIS   | 1          |
| BMGT   | 3       | DM    | 3     | IM     | 3          | LHLE     | <b>3</b> I |
| BMLE   | 3       | DMH   | 3     | IMH    | 3          | LHLT     | 3          |
| BMLT   | 2       | DR1   | 1     | INBC   | <b>4</b> 0 | LHNE     | 3          |
| BMNE   | 2       | DR2   | 1     | INBN   | 35         | LIOT     | 37         |
| BRBR   | 3       | DRN   | 14    | INEC   | 40         | LIP      | <b>2</b>   |
| BRBS   | 3       | DRNM  | 5     | INEN   | 35         |          | 3          |
| BRD1   | 3       | LIRNP | 10    | INH    | 3          |          | 3          |
|        | ა<br>   | URNZ  | 9<br> |        | 6          | I LMCM   | 4          |

Table D-2 I Mode Instruction Weights

| Mnem   | Units | 1 Mnem  | Units |     | Mnem          | Units |   | Mnem            | Units                  | <br> <br>  - |
|--------|-------|---------|-------|-----|---------------|-------|---|-----------------|------------------------|--------------|
| LNE    | 3     | QFDV    | 489   | I   | SHR2          | 2     | Ι | TMH             | 1                      | 1            |
| LPID   | 6     | I QFLD  | 14    | Ι   | SL1           | 1     |   | TRFL            | 2                      | - I          |
| LPSW   | 14    | I QFMP  | 65    | Т   | SL2           | 1     | Ι | TSTQ            | 7                      | I            |
| I LT   | 2     | I QFSB  | 57    | Ι   | SR1           | 1     | I | WAIT            | 58                     | ł            |
| M      | 13    | I QFST  | 19    | - 1 | SR2           | 2     | I | Х               | 1                      | 1            |
| MH     | 8     | I QIINQ | 55    | I   | SSM           | 1     | I | XAD             | 76+3*N                 | 1            |
| N      | 1     | I QIQR  | 56    | - 1 | SSP           | 1     | I | XBTD            | <b>4</b> 0+5* <b>N</b> | I            |
| I NFYB | 35    | I RBQ   | 20    | Τ   | SSSN          | 37    | Ι | XCM             | 80+2*N                 | I            |
| NFYE   | 35    | RCB     | 1     | Т   | $\mathbf{ST}$ | 2     | Ι | XDTB            | 40+5*N                 | I            |
| I NH   | 1     | RMC     | 15    | I   | STAR          | 13    | I | XDV             | 90+65*#                | I            |
| I NOP  | 1     | ROT     | N+2   | Т   | STC           | 12    | I | XED             | Varies                 | Ι            |
| I 0    | 1     | RRST    | 44    | Т   | STCD          | 9     | Ι | XH              | 1                      | Ι            |
| OH     | 1     | RSAV    | 85    | - I | STCH          | 9     | l | XMP             | 88+15*S*D              | I            |
| I OTK  | 9     | I RTQ   | 18    | - I | STEX          | 9     | 1 | XMV             | 80+3* <b>N</b>         | Ι            |
| PCL    | 40+A  | RTS     | 10    | 1   | STFA          | 8     | I | ZCM             | 20+ <b>N</b>           | l            |
| PID    | 3     | S       | 1     | ł   | STH           | 2     | 1 | ZED             | Varies                 | I            |
| I PIDH | 2     | I SCB   | 1     | Т   | STPM          | 12    | 1 | $\mathbf{ZFIL}$ | 14+0.5*N               | 1            |
| I PIM  | 4     | I SOC   | 5     | Т   | STIM          | 17    | 1 | ZM              | 2                      | I            |
| I PIMH | 3     | SH      | 1     | - 1 | SVC           | 36    | I | ZMH             | 2                      | I            |
| PRTN   | 16    | SHA     | N+2   | Т   | TC            | 2     | Ι | ZMV             | 18+0.75*N              | I            |
| PTLB   | 400   | I SHL   | N+2   | I   | TCH           | 2     | ļ | ZMVD            | 14+0.75*N              | 1            |
| I QFAD | 56    | SHL1    | 1     | I   | TCNP          | 2     | ł | ZTRN            | 14+8*N                 | I            |
| QFC    | 24    | I SHL2  | 1     | I   | TFLR          | 3     |   |                 |                        | I            |
| QFCM   | 10    | I SHR1  | 1     | I   | TM            | 1     | Ι |                 |                        | l            |

# Table D-2 (Continued) I Mode Instruction Weights

Examination of the V and I mode instruction weights shows that certain instructions have much activity in them and thus take much longer to complete execution. Such instructions include STIR/LDLR and STAR/LDAR (both 13/11 units) that store/load the L register into the addressed register. Other such instructions are RSAV/RRST (44/85 units) that save/restore all registers.

Other instructions are very fast, such as the long loads (LDL and L) at one unit each.

Prime processor designers have worked hard to make the instructions that "feel" fast be fast. "Cute" uses of instructions are usually punished by reduced performance. An example of "cute" instruction use is LDX# 2 instead of STL Temp, LDX Temp+1. Clever use exploits the address modes and multiple index registers to save instructions. Clever use of registers can save stores, but shuffling data from one register to another (even in I mode) to save a store has little value. Restricted instructions are shown in these tables. Even though several of these are heavily weighted, they are not discussed here since they are Ring O instructions.

Also, short integer (16-bit) instructions take less time to execute than long integer (32-bit) ones, particularly in the case of multiplies and divides. For V mode, long integer arithmetic mnemonics end in "L", such as MPL and DVL, while short integer ones do not, as in MPY and DIV. I mode short integer mnemonics end in "H" (half register), such as MH and DH, while long integer ones are simply M and D for multiply long and divide long.

For all processors, be sure to use the ZMVD (Move Characters between Equal Length Strings) instruction when moving bulk data. ZMVD is the most efficient means for data moving. All of Prime software is learning to use this instruction for bulk data transfers. Prime processors are optimized for ZMVD.

The advantage of using these tables of weighted instruction times is obvious if you are programming in PMA. If you are programming in a high level language such as FORTRAN or Pascal, however, you first need to generate an expanded listing when you are compiling your source program. Such a listing shows the PMA code that the compiler generated for each source statement. Simple arithmetic will show the approximate relative weights that each source statement takes.

#### EXTENSIONS TO INSTRUCTION WEIGHTS

Unfortunately, no simple calculation can accurately produce the actual instruction time of any modern machine (including all of Prime's, of course). Many factors influence the execution of a single instruction. The most important is, of course, the processor type. However, many other factors also affect execution time. Address formation and virtual memory considerations are shown in Table D-3. Other factors are harder to describe and so are deemed less important. Among them are I/O (DMx) and process exchange activity, interprocessor locking (on the P850), memory refresh, EOCC's, etc.

Table D-3 shows that indexing adds no further time to the basic instruction while indirection adds 1 unit. Unaligned data also adds 1 unit, so be sure to align data on even word (32-bit) boundaries in common blocks. Prime software provides for proper data alignment if possible. Address traps add considerably more time to instruction execution. Read or write address traps add 8 units apiece, and should be avoided. An address trap is invoked in V mode short instructions if the final address is to memory from 0 to 7. The trap is to register file locations.

A time penalty is paid whenever there is a cache miss (13 units) or an STLB miss (31 units), since the virtual-to-physical address translation process has to occur. The more pages used in a program, the higher the probability of a cache miss, STLB miss or a page fault. As a rule of

thumb to keep these delays down, ensure that your programs have their most frequently-used subroutines loaded together -- do not load subroutines on an alphabetic basis.

# Table D-3

# Comparative Weighting Address Formation High End for 32I Mode

| 1                    |                  |              |                            |                            |                           |
|----------------------|------------------|--------------|----------------------------|----------------------------|---------------------------|
| ,<br>Vanilla         | a                | L            | 1,FOO                      | l unit                     |                           |
| I Indexe             | d                | L            | 1,FOO, 2                   | l unit                     |                           |
| Reg-Reg              | g                | L            | 1,2                        | l unit                     |                           |
| Immedia              | ate              | L            | 1,=10                      | l unit                     |                           |
| Indire               | ct               | L            | 1,P\$FOO,*                 | 2 units                    |                           |
| Indire               | ct               | L            | 1,P\$F00,*2                | 2 units                    | (postindexed)             |
| u<br>Unaligi         | ned.             | L            | 1,F00                      | 2 units                    |                           |
| Cache 1              | miss             | L            | 1,F00                      | 14 units                   | (1 only)                  |
| I STLB m:            | iss              | L            | 1,F00                      | 32 units                   | (1 only)                  |
| Worst (<br>  (Four ; | case<br>STLB a   | L<br>nd Ca   | 1,P\$FOO,*<br>che misses,  | 179 units<br>Indirect, I.F | . and operand unaligned.) |
| Address              | Traps            | :            |                            |                            |                           |
| I LDA#               | 6                |              |                            | 9 units                    | (Read address trap)       |
| DFST<br>LDA          | TEMP<br>TEMP+    | 3            |                            | 6 units                    | (Better practice)         |
| STA#                 | 6                |              |                            | 9 units                    | (Write address trap)      |
| I STA<br>I DFLD      | TEMP+<br>TEMP    | 3            |                            | 4 units                    | (Better practice)         |
| "Normal<br>  "Normal | " cach<br>" STLB | e hit<br>hit | rate of 98<br>rate of 99 p | percent<br>ercent          |                           |

# Archived Instructions

This appendix contains archived S, R, V, and I mode instructions. These instructions support options that are no longer offered, or they support functions that are no longer used. Table E-1 contains a summary of the archived instructions. (This table is in the same format as those in Appendix C.) The descriptions of these instructions follow Table E-1.

| _ |      |        |      |       |      |   |   |                                         |
|---|------|--------|------|-------|------|---|---|-----------------------------------------|
| R | Mnem | Opcode | Form | Func  | M    | С | œ | Description                             |
| R | CAI  | 000411 | GEN  | IO    | SRVI | _ | _ | Clear Active Interrupt                  |
|   | CREP | 02     | MR   | PCTLJ | R    | _ | - | Call Recursive Entry<br>Procedure       |
|   | CXCS | 001714 | GEN  | MCIL  | VI   | 6 | 5 | Control Extended Control<br>Store       |
| R | EMCM | 000503 | GEN  | INIGY | SRVI | _ | - | Enter Machine Check Mode                |
|   | ENIR | 01 03  | MR.  | PCILJ | R    | - | - | Enter Recursive Procedure<br>Stack      |
| R | ESIM | 000415 | GEN  | IO    | SRVI | _ | _ | Enter Standard Interrupt Mode           |
| R | EVIM | 000417 | GEN  | IO    | SRVI | _ | _ | Enter Vectored Interrupt Mode           |
|   | JEO  | 02 03  | MR   | PCTLJ | R    | _ | _ | Jump on A Equal to 0                    |
|   | JGE  | 07 03  | MR.  | PCTLJ | R    | - | - | Jump on A Greater Than or<br>Equal to O |

Table E-1 Archived Instruction Summary

| R      | Mnem                 | Opcode | Form | Func  | M          | С | œ | Description                              |
|--------|----------------------|--------|------|-------|------------|---|---|------------------------------------------|
|        | JGT                  | 05 03  | MR   | PCTLJ | R          | _ |   | Jump on A Greater Than O                 |
|        | JIE                  | 04 03  | MR   | PCILJ | R          | - | - | Jump on A Less Than or Equal<br>to 0     |
|        | $\operatorname{JLT}$ | 06 03  | MR.  | PCTLJ | R          | _ | - | Jump on A Less Than O                    |
|        | JNE                  | 03 03  | MR   | PCTLJ | R          | - | — | Jump on A Not Equal to O                 |
| R      | LMCM                 | 000501 | GEN  | INTGY | SRVI       | - | - | Leave Machine Check Mode                 |
|        | LWCS                 | 001710 | GEN  | MCIL  | VI         | 6 | 5 | Load Writable Control Store              |
| R      | MDEI                 | 001304 | GEN  | INIGY | VI         | 6 | 5 | Memory Diagnostic Enable<br>Interleave   |
| R      | MDII                 | 001305 | GEN  | INIGY | VI         | 6 | 5 | Inhibit Interleaved                      |
| R      | MDIW                 | 001324 | GEN  | INIGY | VI         | 6 | 5 | Write Interleaved                        |
| R      | MDRS                 | 001306 | GEN  | INIGY | VI         | 6 | 5 | Read Syncrome Bits                       |
| R      | MDWC                 | 001307 | GEN  | INIGY | VI         | 6 | 5 | Load Write Control Register              |
|        | MIA                  | 64     | MRGR | MCIL  | I          | _ | - | Microcode Entrance                       |
|        | MIA                  | 12 01  | MR   | MCIL  | V          | - | - | Microcode Entrance                       |
|        | MIB                  | 74     | MRGR | MCIL  | I          | _ | _ | Microcode Entrance                       |
|        | MTB                  | 13 01  | MR.  | MCTL  | v          | _ | _ | Microcode Entrance                       |
|        | NRM                  | 000101 | GEN  | TNT   | SR         | 8 | _ | Normalize                                |
|        | RTN                  | 000105 | GEN  | PCTLJ | SR         | _ | _ | Return                                   |
|        | SCA                  | 000041 | GEN  | TNT   | SR         | _ | _ | Load Shift Count into A                  |
| R      | SNR                  | 100247 | GEN  | SKTP  | SRV        | _ | _ | Skin on Sense Switch N Reset             |
| Ð      | CNIC                 | 101041 | CEN  | OWID  |            |   |   | to 0                                     |
| r<br>r | GNG                  | 101244 | GEN  | ONIP  | <u>ORV</u> | - | - | to 1                                     |
| R      | SRI                  | 100050 | GEN  | SKIP  | SRV        | - | - | to 0                                     |
| R      | SR2                  | 100010 | GEN  | SKIP  | SRV        | - | - | Skip on Sense Switch 2 Reset<br>to 0     |
| R      | SR3                  | 100004 | GEN  | SKIP  | SRV        | - | - | Skip on Sense Switch 3 Reset<br>to 0     |
| R      | SR4                  | 100002 | GEN  | SKIP  | SRV        | - | - | Skip on Sense Switch 4 Reset             |
| R      | SS1                  | 101020 | GEN  | SKIP  | SRV        | - | - | Skip on Sense Switch 1 Set               |
| R      | SS2                  | 101010 | GEN  | SKIP  | SRV        | _ | - | Skip on Sense Switch 2 Set               |
| R      | SS3                  | 101004 | GEN  | SKIP  | SRV        |   | - | Skip on Sense Switch 3 Set               |
| R      | SS4                  | 101002 | GEN  | SKIP  | SRV        | _ | - | Skip on Sense Switch 4 Set               |
| R      | SSR                  | 100036 | GEN  | SKIP  | SRV        | - | - | Skip on All Sense Switches<br>Reset to O |
| R      | SSS                  | 101036 | GEN  | SKIP  | SRV        | - | - | Skip on Any Sense Switches<br>Set to 1   |
|        | VIRY                 | 000311 | GEN  | INIGY | SRVI       | 6 | 5 | Verify                                   |
|        | WCS                  | 0016XX | GEN  | MCTL  | RVI        | _ | _ | Write Control Store                      |
|        | XVRY                 | 001113 | MCTL | GEN   | VI         | 6 | 5 | Verify XIS                               |

Table E-1 (continued) Archived Instruction Summary

CAI Clear Active Interrupt 0 0 0 0 0 0 0 1 0 0 0 1 0 0 1 (S, R, V, I mode form)

Clears the current active interrupt. Effective only in vectored interrupt mode. Inhibits interrupts for one instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This is a restricted instruction.

CREP address
Call Recursive Entry Procedure
I X 1 0 0 0 1 1 0 0 0 0 1 0 CB\2 (R mode form)
[ DISPLACEMENT\16 ]

Increments the contents of the program counter and loads the result into the location following the one specified by the current value of the R mode stack pointer. Calculates an effective address, EA, and loads it into the program counter. Execution continues with the location specified by the new value of the program counter.

This instruction performs subroutine linkage for reentrant or recursive procedures. CREP stores the return address in bits 17-32 (the second halfword) of a stack frame created by the ENTR instruction, rather than in the destination address as JST does. Leaves the values of CBIT, LINK, and the condition codes indeterminate.

CXCS Control Extended Control Store 0000001111001100 (V, I mode form)

Moves the A register contents to the control register on the writable control store board. Leaves the values of CBIT, LINK, and the condition codes indeterminate.

# ► EMCM

Enter Machine Check Mode 000000101000011 (S. R. V. I mode form)

Enters machine check mode 3 by loading 3 into modal bits 15-16. This mode enables the reporting of all errors. The actions taken upon an error depend on whether the machine was in process exchange mode or not.

The instruction inhibits interrupts during execution of the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. See Chapter 10 of the <u>System Architecture Reference Guide</u> for more information about checks.

If an error occurs in process exchange mode, the microcode stores the machine state in the appropriate check vector and transfers control to that vector, automatically dropping back to machine check mode 0.

If an error occurs when the machine is not in process exchange mode, the following actions occur. If the appropriate check vector contains a nonzero value, the processor jumps indirectly through this vector to the check routine. If the check vector location contains 0, the machine halts.

#### Note

#### This is a restricted instruction.

ENTR n Enter R Mode Recursive Procedure Stack I X 0 0 0 1 1 1 0 0 0 0 1 1 CB\2 (R mode long form) [ DISPLACEMENT\16 ]

Creates a save area n halfwords long. (A halfword is 16 bits.) Saves the current value of the R mode stack pointer in the first halfword of the save area. The starting address of the save area is:

( contents of R mode stack pointer ) - n

This means that the instruction creates a stack frame containing n locations, and that the first location points to the previous frame.

The ENTR instruction leaves the values of CBIT, LINK, and the condition codes unchanged.

ESIM

Enter Standard Interrupt Mode 000000100001101 (S, R, V, I mode form)

Enters standard interrupt mode by resetting bit 2 of the modals to 0. Inhibits interrupts for one instruction. ESIM is meaningless when the system is in process exchange mode (that is, the value of modal bit 13 is 1). All interrupts use location '63. The processor services interrupts according to their relative positions on the I/O bus. Lower devices have higher priority. Inhibits interrupts during execution of the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged. Refer to Chapter 10 of the <u>System</u> Architecture Reference Guide for more information about interrupts.

Second Edition

# Note

# ESIM is a restricted instruction.

# EVIM Enter Vectored Interrupt Mode 0 0 0 0 0 0 0 1 0 0 0 0 1 1 1 1 (S, R, V, I mode form)

Enters vectored interrupt mode by setting bit 2 of the modals to 1. EVIM is meaningless when the system is in process exchange mode (that is, the value of modal bit 13 is 1). The processor services interrupts according to their relative positions on the I/O bus. Lower devices have higher priority. Interrupts occur through a location specified by the interrupting device. Inhibits interrupts during execution of the next instruction. Leaves the values of LINK, CBIT, and the condition codes unchanged. Refer to Chapter 10 of the <u>System Architecture</u> Reference Guide for more information about interrupts.

#### Note

This is a restricted instruction.

JEQ address Jump on A Equal to 0 I X 0 0 1 0 1 1 0 0 0 0 1 1 CB\2 (R mode form) [ DISPLACEMENT\16 ]

Calculates an effective address, EA. Loads EA into the program counter if the contents of A are equal to 0. If the contents of A are not equal to 0, execution continues with the next instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

▶ JGE address Jump on A Greater Than or Equal to 0 I X 0 1 1 1 1 1 0 0 0 0 1 1 CB\2 (R mode form) [ DISPLACEMENT\16 ]

Calculates an effective address, EA. If the contents of A are greater than or equal to 0, the instruction loads EA into the program counter. If the contents of A are less than 0, execution continues with the next instruction. Leaves the contents of CBIT, LINK, and the condition codes unchanged. JGT address
Jump on A Greater Than 0
I X 0 1 0 1 1 1 0 0 0 0 1 1 CB\2 (R mode form)
[ DISPLACEMENT\16 ]

Calculates an effective address, EA. If the contents of A are greater than 0, the instruction loads EA into the program counter. If the contents of A are less than or equal to 0, execution continues with the next instruction. Leaves the contents of CBIT, LINK, and the condition codes unchanged.

JLE address
Jump on A Less Than or Equal to 0
I X 0 1 0 0 1 1 0 0 0 0 1 1 CB\2 (R mode form)
[ DISPLACEMENT\16 ]

Calculates an effective address, EA. If the contents of A are less than or equal to 0, the instruction loads EA into the program counter. If the contents of A are greater than 0, execution continues with the next instruction. Leaves the contents of LINK, CBIT, and the condition codes unchanged.



JLT address
Jump on A Less Than 0
I X 0 1 1 0 1 1 0 0 0 0 1 1 CB\2 (R mode form)
[ DISPLACEMENT\16 ]

Calculates an effective address, EA. If the contents of A are less than 0, the instruction loads EA into the program counter. If the contents of A are greater than 0, execution continues with the next instruction. Leaves the contents of CBIT, LINK, and the condition codes unchanged.

JNE address Jump on A Not Equal to 0 I X 0 0 1 1 1 1 0 0 0 0 1 1 CB\2 (R mode form) [ DISPLACEMENT\16 ]

Calculates an effective address, EA. If the contents of A do not equal 0, the instruction loads EA into the program counter. If the contents of A are equal to 0, execution continues with the next instruction. Leaves the contents of CBIT, LINK, and the condition codes unchanged.

LMCM Leave Machine Check Mode 000000101000001 (S, R, V, I mode form)

Leaves machine check mode by setting bits 15-16 of the modals to 00. If a machine parity error occurs in this mode, the hardware sets the machine check flag but no check (V mode) or interrupt (S, R modes) occurs. Inhibits the machine for one instruction. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This is a restricted instruction.

LWCS Load Writable Control Store 0000001111001000 (V, I mode form)

Loads the writable control store portion of the extended control store board from the memory block pointed to by XB. The control register loaded by CXCS modifies this instruction. Leaves the values of CBIT, LINK, and the condition codes indeterminate.

MDET

Memory Diagnostic Enable Interleave 0000001011000100 (V, I mode form)

Enables the memory interleave facility. Leaves the values of LINK, CBIT, and the condition codes unchanged.

#### Note

#### This is a restricted instruction.

MDII

Memory Diagnostic Inhibit Interleave 0 0 0 0 0 0 1 0 1 1 0 0 0 1 0 1

(V, I mode form)

Inhibits the memory interleave facility. Leaves the values of LINK, CBIT, and the condition codes unchanged.

### Note

This is a restricted instruction.

MDIW

Memory Diagnostic Write Interleaved 0000001011010100

Writes interleaved memory. Leaves the values of LINK, CBIT, and the condition codes unchanged.

(V, I mode form)

#### Note

This is a restricted instruction.

MDRS

Memory Diagnostic Read Syndrome Bits 0000001011000110 (V, I mode form)

Reads memory syndrome bits. Leaves the values of LINK, CBIT, and the condition codes unchanged.

#### Note

This is a restricted instruction.

MDWC Memory Diagnostic Load Write Control Register 0000001011000111 (V, I mode form)

Writes memory control register. Leaves the values of LINK, CBIT, and the condition codes unchanged.

#### Note

This is a restricted instruction.

MIA Microcode Execute A IX101011000Y01ER\2 (V mode long form) DISPLACEMENT\16

1 1 0 1 0 0 DR/3 TM/2 SR/3 BR/2 (I mode form) [DISPLACEMENT/16]

This instruction currently causes a UII fault. If implemented, this instruction is for user-written microcode. For more information about UII, refer to Chapter 10 of the System Architecture Reference Guide.

MIB Microcode Execute B IX101111000Y01ER\2 (V mode long) DISPLACEMENT\16 111100DR\3 TM\2 SR\3 ER\2 (I mode form)

[ DISPLACEMENT\16 ]

This instruction currently causes a UII fault. If implemented, this instruction is for user-written microcode. For more information about UII, refer to Chapter 10 of the System Architecture Reference Guide.

NRM Normalize 00000000100001 (S, R mode form)

Shifts the 31-bit integer in A and B to the left arithmetically, shifting in Os into bit 16 of B. The shift does not affect bit 1 of B or bit 1 of A. The instruction shifts bits out of bit 2 in A until the value of bit 2 is opposite the value of bit 1 in A. Loads bits 9-16 of the S and R mode keys with the number of shifts performed.

Normalizing 0 on all machines results in the following: zeros are loaded in bits 9-16 of the keys; bit 1 of the B register is ignored in the test for zero. Bit 1 of the B register may be reset or left unchanged, depending on the processor.

Leaves the values of CBIT and the condition codes unchanged; the value of LINK is indeterminate.

Note

Since the bits shifted out of bit 2 in A contain copies of the sign of the 31-bit number, the shift results in no loss of information.

RTN Return 000000001000101 (R mode form)

Returns control from a P300 recursive procedure to the calling routine. To do this, RTN fetches the return address from the second halfword of the previous stack frame and loads the result in the program counter. RTN then transfers halfword 1 (the pointer to the preceding stack frame) to the S register. (A halfword is 16 bits.)

(S)+1 -> P (S) -> S If the return address is 0, (S) is unchanged and a PSU (Procedure Stack Underflow) fault is taken (interrupt through location '75 in physical memory is taken on the Prime 300). Leaves the values of LINK, CBIT, and the condition codes unchanged.

#### Note

This instruction reverses the actions done by CREP and ENTR.

SCA Load Shift Count Into A 0000000000100001 (S, R mode form)

Loads the contents of bits 9-16 of the keys into bits 9-16 of A. Clears bits 1-8 of A to 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

The SCA instruction is used with NRM.

SNR n Skip on Sense Switch N Reset to 0 1000000101010N\4 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the contents of sense switch N are O. Leaves the values of CBIT, LINK, and the condition codes unchanged.

N specifies the sense switch to test.

#### Note

This is a restricted instruction.

SNS Skip on Sense Switch N Set to 1 100000101010N\4 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the value of sense switch N is 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

N specifies the sense switch to test.

#### Note

SNS is a restricted instruction.

SR1 Skip on Sense Switch 1 Reset to 0 1000000000010000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the value of sense switch 1 is 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

#### This is a restricted instruction.

SR2

Skip on Sense Switch 2 Reset to 0 100000000000000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the value of sense switch 2 is 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This is a restricted instruction.

Skips the next sequential 16-bit halfword if the value of sense switch 3 is 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This is a restricted instruction.

SR4

Skips the next sequential 16-bit halfword if the value of sense switch 4 is 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This is is a restricted instruction.

SS1 Skip on Sense Switch 1 Set to 1 1000001000010000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the value of sense switch 1 is 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This is a restricted instruction.

SS2

Skip on Sense Switch 2 Set to 1 100000100001000 (S. R. V mode form)

Skips the next sequential 16-bit halfword if the value of sense switch 2 is 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This is a restricted instruction.

SS3 Skip on Sense Switch 3 Set to 1 100000100000100 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the value of sense switch 3 is 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

# Note

This is a restricted instruction.

SS4 Skip on Sense Switch 4 Set to 1 10000010000000000 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the value of sense switch 4 is 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

#### This is a restricted instruction.

SSR Skip on All Sense Switches Reset to 0 100000000011110 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the values of sense switches 1, 2, 3, and 4 are all 0. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This is a restricted instruction.

SSS Skip on Any Sense Switches Set to 1 1000001000011110 (S, R, V mode form)

Skips the next sequential 16-bit halfword if the values of sense switches 1, 2, 3, and 4 are all 1. Leaves the values of CBIT, LINK, and the condition codes unchanged.

#### Note

This is a restricted instruction.

VIRY Verify 0311 opcode 000000011001001 (S, R, V mode form)

Executes the verification routine. If there is a failure of any kind, the processor goes on to the next instruction with the number of the test that failed in register A. If there are no errors, the processor skips the next sequential instruction.

If the processor does not have the verification routine, this instruction executes as no-op.

▶ WCS n

Writable Control Store 0000001110N\6 (R, V, I mode form)

Reserved set of 64 op codes to serve as microcode entrances, where <u>n</u> is 0 through 63.

# > XVRY

XIS Board Verify 1113 opcode 0000001001001011 (S, R, V mode form)

XVRY executes a Prime 500 microcode diagnostic routine tht checks the integrity of the XIS board. If the XIS board is not functional, the processor does not skip the next instruction and the A register holds the failed micro-diagnostic test number. If the processor passes the verify instruction, it skips the next instruction.

The codes and tests are:

'72 Data Move Test - Load and Unload XIS Board

- '73 Normalize Test Adjust Test
- '74 Binary Multiply
- '75 Binary Divide
- '76 Decimal Arithmetic

# 2455 Instruction Sets

The 2455 processor has now been added to the Prime 50 Series computers. This new processor shares the architecture and operating system that is common to all 50 Series processors and makes the 50 Series a line of completely upward-compatible and downward-compatible systems.

The implementation of the common architecture, however, can be slightly different for each member of the 50 Series, allowing the different processors to address a wide variety of user needs while remaining compatible.

The architectural implementation of the 2455 is identical to that of the 2755 processor. This means that instruction set features that apply to the 2755 apply equally well to the 2455. The only exception to this is the STPM (Store Processor Model) instruction: the processor model number code for the 2455 is 32L (decimal).



# READER RESPONSE FORM

Instruction Sets Guide DOC9474-2LA

| of our   | publications.                       |                  | -                                      | -           |                                       |                  |             |
|----------|-------------------------------------|------------------|----------------------------------------|-------------|---------------------------------------|------------------|-------------|
| 1.       | . How do you rate this              | document f       | for overall u                          | usefulness? |                                       |                  |             |
|          | □ excellent □ ve                    | ry good          | 🗆 good                                 | $\Box f d$  | ıir                                   | □ <i>po</i>      | or          |
| 2.       | . What features of this             | manual did       | you find r                             | most usefu  | .1?                                   |                  |             |
|          |                                     |                  |                                        |             |                                       |                  |             |
|          |                                     |                  | ······································ |             |                                       |                  |             |
| 3.       | . What faults or errors             | in this man      | nual gave y                            | ou probler  | ns?                                   |                  |             |
|          |                                     |                  |                                        |             |                                       |                  |             |
|          |                                     |                  |                                        |             |                                       |                  |             |
|          |                                     |                  |                                        |             |                                       |                  |             |
| 4.       | . How does this manua<br>companies? | l compare t      | o equivalent                           | : manuals   | produced                              | by oth           | er computer |
|          | □ Much better<br>□ Much worse       | □ Slig<br>□ Slig | ghtly better<br>ghtly worse            |             | <ul><li>About</li><li>Can't</li></ul> | the san<br>judge | me          |
| 5.       | . Which other companie              | s' manuals       | nave you re                            | ad?         |                                       |                  |             |
|          |                                     |                  | · ·                                    |             |                                       |                  | <u></u>     |
| Name:    |                                     |                  | Position:                              |             |                                       |                  |             |
| Company  | y:                                  |                  |                                        |             |                                       |                  |             |
| 1001000. |                                     |                  |                                        |             |                                       |                  |             |
|          |                                     |                  | Postal C                               | Code:       |                                       |                  |             |

First Class Permit #531 Natick, Massachusetts 01760

# **BUSINESS REPLY MAIL**

Postage will be paid by:



Attention: Technical Publications Bldg 10 Prime Park, Natick, Ma. 01760





